Aller au contenu

Minio

Introduction

Nous allons installer un serveur S3 minio pour y stocker les sauvegardes de nos volumes persistants et de la config de notre environnement kuberntes.

Prérequis

  • un serveur Rocky 9
  • disque supplémentaire sur notre VM (20G)
Nom du serveur Adresse IP Rôle
minio1 172.31.10.13 serveur S3

Installation

Préparation du disque

sudo pvcreate /dev/sdb
sudo vgcreate datavg /dev/sdb
sudo lvcreate -l 100%VG -n datalv datavg
sudo mkfs.xfs /dev/mapper/datavg-datalv
sudo mkdir /mnt/data
sudo sh -c 'echo "/dev/mapper/datavg-datalv /mnt/data                   xfs     defaults        0 0" >> /etc/fstab'
sudo mount -a
df -h

Groupe et utilisateur

sudo groupadd -r minio-user
sudo useradd -M -r -g minio-user minio-user
sudo chown minio-user:minio-user /mnt/data

Installation de minio

Serveur

wget https://dl.min.io/server/minio/release/linux-arm64/minio
sudo mv minio /usr/local/bin/
sudo chmod +x /usr/local/bin/minio

Client

sudo wget https://dl.min.io/client/mc/release/linux-arm64/mc
sudo mv mc /usr/local/bin/
sudo chmod +x /usr/local/bin/mc

Création du fichier de service systemd

sudo cat << EOF | sudo tee /etc/systemd/system/minio.service
[Unit]
Description=MinIO
Documentation=https://min.io/docs/minio/linux/index.html
Wants=network-online.target
After=network-online.target
AssertFileIsExecutable=/usr/local/bin/minio

[Service]
WorkingDirectory=/usr/local/bin

User=minio-user
Group=minio-user
ProtectProc=invisible

EnvironmentFile=-/etc/default/minio
ExecStartPre=/bin/bash -c "if [ -z \"\${MINIO_VOLUMES}\" ]; then echo \"Variable MINIO_VOLUMES not set in /etc/default/minio\"; exit 1; fi"
ExecStart=/usr/local/bin/minio server \$MINIO_OPTS \$MINIO_VOLUMES

# Let systemd restart this service always
Restart=always

# Specifies the maximum file descriptor number that can be opened by this process
LimitNOFILE=65536

# Specifies the maximum number of threads this process can create
TasksMax=infinity

# Disable timeout logic and wait until process is stopped
TimeoutStopSec=infinity
SendSIGKILL=no

[Install]
WantedBy=multi-user.target

# Built for \${project.name}-\${project.version} (\${project.name})
EOF

Configuration serveur

Note

Remplacer le mot de passe adminPasswordAChanger ci-dessous

sudo cat << EOF | sudo tee /etc/default/minio
# MINIO_ROOT_USER and MINIO_ROOT_PASSWORD sets the root account for the MinIO server.
# This user has unrestricted permissions to perform S3 and administrative API operations on any resource in the deployment.
# Omit to use the default values 'minioadmin:minioadmin'.
# MinIO recommends setting non-default values as a best practice, regardless of environment

MINIO_ROOT_USER=minioadmin
MINIO_ROOT_PASSWORD=adminPasswordAChanger

# MINIO_VOLUMES sets the storage volume or path to use for the MinIO server.

MINIO_VOLUMES="/mnt/data"

# Use if you want to run Minio on a custom port.
MINIO_OPTS="--address :9000 --console-address :9001"

# MINIO_SERVER_URL sets the hostname of the local machine for use with the MinIO Server
# MinIO assumes your network control plane can correctly resolve this hostname to the local machine

# Uncomment the following line and replace the value with the correct hostname for the local machine.

#MINIO_SERVER_URL="http://minio.example.net"
EOF

Firewall

sudo firewall-cmd --permanent --add-port=9000/tcp
sudo firewall-cmd --permanent --add-port=9001/tcp
sudo firewall-cmd --reload

Démarrer le service minio

sudo systemctl start minio.service
sudo systemctl enable minio.service
sudo systemctl status minio.service
sudo journalctl -f -u minio.service

La résultat de la commande journalctl doit ressembler à ce qui suit:

-- Logs begin at Tue 2023-02-21 12:19:58 CET. --
Feb 21 13:45:28 gmoos3.ville-geneve.ch minio[7818]: MinIO Object Storage Server
Feb 21 13:45:28 gmoos3.ville-geneve.ch minio[7818]: Copyright: 2015-2023 MinIO, Inc.
Feb 21 13:45:28 gmoos3.ville-geneve.ch minio[7818]: License: GNU AGPLv3 <https://www.gnu.org/licenses/agpl-3.0.html>
Feb 21 13:45:28 gmoos3.ville-geneve.ch minio[7818]: Version: RELEASE.2023-02-17T17-52-43Z (go1.19.6 linux/amd64)
Feb 21 13:45:28 gmoos3.ville-geneve.ch minio[7818]: Status:         1 Online, 0 Offline.
Feb 21 13:45:28 gmoos3.ville-geneve.ch minio[7818]: API: http://172.31.10.13:9000  http://127.0.0.1:9000
Feb 21 13:45:28 gmoos3.ville-geneve.ch minio[7818]: Console: http://172.31.10.13:9001 http://127.0.0.1:9001
Feb 21 13:45:28 gmoos3.ville-geneve.ch minio[7818]: Documentation: https://min.io/docs/minio/linux/index.html

Configuration du client

mc alias set minioadmin http://localhost:9000 minioadmin adminPasswordAChanger

Note

Le mot de passe adminPasswordAChanger doit correspondre à celui défini dans /etc/default/minio (MINIO_ROOT_PASSWORD=)

Création de bucket

Nos allons créer deux buckets longhorn-backup et velero-backups avec chacun un utilisateur et une politique d'accès

mc mb minioadmin/longhorn-backups
mc mb minioadmin/velero-backups

Utilisateur

Création d'utilisateur

mc admin user add minioadmin longhorn-backups-user userPasswordAChanger
mc admin user add minioadmin velero-backups-user userPasswordAChanger

Configuration du client

mc alias set longhorn-backups-user http://localhost:9000 longhorn-backups-user userPasswordAChanger
mc alias set velero-backups-user http://localhost:9000 velero-backups-user userPasswordAChanger

Note

Le mot de passe userPasswordAChanger doit correspondre à celui défini lors de la création des utilisateurs ci-dessus.

Attribution des politiques

Longhorn

cat > /tmp/longhorn-backups-policy.json <<EOF
{
  "Version": "2012-10-17",
      "Statement": [
    {
      "Action": [
        "s3:PutBucketPolicy",
        "s3:GetBucketPolicy",
        "s3:DeleteBucketPolicy",
        "s3:ListAllMyBuckets",
        "s3:ListBucket"
      ],
      "Effect": "Allow",
      "Resource": [
        "arn:aws:s3:::longhorn-backups"
      ],
      "Sid": ""
    },
    {
      "Action": [
        "s3:AbortMultipartUpload",
        "s3:DeleteObject",
        "s3:GetObject",
        "s3:ListMultipartUploadParts",
        "s3:PutObject"
      ],
      "Effect": "Allow",
      "Resource": [
        "arn:aws:s3:::longhorn-backups/*"
      ],
      "Sid": ""
    }
  ]
}
EOF
mc admin policy create minioadmin longhorn-backups-policy /tmp/longhorn-backups-policy.json
mc admin policy attach minioadmin longhorn-backups-policy --user=longhorn-backups-user

Velero

cat > /tmp/velero-backups-policy.json <<EOF
{
  "Version": "2012-10-17",
      "Statement": [
    {
      "Action": [
        "s3:PutBucketPolicy",
        "s3:GetBucketPolicy",
        "s3:DeleteBucketPolicy",
        "s3:ListAllMyBuckets",
        "s3:ListBucket"
      ],
      "Effect": "Allow",
      "Resource": [
        "arn:aws:s3:::velero-backups"
      ],
      "Sid": ""
    },
    {
      "Action": [
        "s3:AbortMultipartUpload",
        "s3:DeleteObject",
        "s3:GetObject",
        "s3:ListMultipartUploadParts",
        "s3:PutObject"
      ],
      "Effect": "Allow",
      "Resource": [
        "arn:aws:s3:::velero-backups/*"
      ],
      "Sid": ""
    }
  ]
}
EOF
mc admin policy create minioadmin velero-backups-policy /tmp/velero-backups-policy.json
mc admin policy attach minioadmin velero-backups-policy --user=velero-backups-user

Accès à l'interface WEB

http://srvminio.gmolab.net:9001

Le username et le password correspondent à ceux définis dans /etc/default/minio

MINIO_ROOT_USER=minioadmin
MINIO_ROOT_PASSWORD=adminPasswordAChanger

Source

Deploy single node
Using MinIO as Backup Target Longhorn Download minio


Version Date Change Auteur
1.0 28.03.2023 Création GMo