Minio 分布式集群安装配置
目录创建
mkdir -p /opt/minio/run && mkdir -p /etc/minio && mkdir -p /indata/disk_0/minio/data
- run:启动脚本及二进制文件目录
- /etc/minio:配置文件目录
- data:数据存储目录
下载 minio
wget https://dl.min.io/server/minio/release/linux-amd64/minio -P /opt/minio/run/
配置启动文件
vi /opt/minio/run/run.sh
#!/bin/bash
export MINIO_ROOT_USER=Minio
export MINIO_ROOT_PASSWORD=Test1234!
/opt/minio/run/minio server --config-dir /etc/minio --address ":9000" --console-address ":9001" \
http://192.168.1.1/indata/disk_0/minio/data \
http://192.168.1.2/indata/disk_0/minio/data \
http://192.168.1.3/indata/disk_0/minio/data
- MINIO_ROOT_USER : 用户名,长度最小是5个字符 (对应弃用配置: MINIO_ACCESS_KEY)
- MINIO_ROOT_PASSWORD : 密码,密码不能设置过于简单,不然minio会启动失败,长度最小是8个字符 (对应弃用配置: MINIO_SECRET_KEY)
- –config-dir :指定集群配置文件目录
- 这里的用户名和密码既可以作为页面的登录用户密码,也可以作为连接 s3a 文件的密钥
- –address “:9000” : 后端 API 服务监听的网络地址,: 表示监听所有可用的网络接口(即服务器上的所有 IP 地址);9000 是默认的 API 端口号
- –console-address “:9001” : 该参数指定 MinIO 内置管理控制台(Web UI)监听的网络地址;同样使用 : 表示监听所有网络接口;9001 是默认的控制台端口号
如果使用弃用的 MINIO_ACCESS_KEY 和 MINIO_SECRET_KEY 则会有告警:
INFO: WARNING: MINIO_ACCESS_KEY and MINIO_SECRET_KEY are deprecated. Please use MINIO_ROOT_USER and MINIO_ROOT_PASSWORD
如果服务器配置了代理(如 clash代理),则可能会导致启动失败,需要在 run.sh 中添加(启动命令前):
unset http_proxy
unset https_proxy
这样就可以在启动 minio 时不走代理地址了~
配置为系统服务
vi /usr/lib/systemd/system/minio.service
[Unit]
Description=Minio service
Documentation=https://docs.minio.io/[Service]
WorkingDirectory=/indata/disk_0/minio/data
ExecStart=/opt/minio/run/run.shRestart=on-failure
RestartSec=5[Install]
WantedBy=multi-user.target
注意:这里的路径要和前面的配置一致
启动集群
systemctl daemon-reload
systemctl enable minio && systemctl restart minio
systemctl status minio
每个节点均返回如下结果则代表成功
可以通过查看端口进程进一步确认
这种方式返回的启动日志可能不是很全,可以直接运行脚本查看更完整的日志
可以看到第一个启动的节点会一直等待其他节点连接成功。
Web UI
浏览器输入集群任意节点地址+9001 (输入9000会自动跳转到9001)端口,即可访问minio:
http://192.168.1.1:9001/
http://192.168.1.2:9001/
http://192.168.1.3:9001/
登录
创建Bucket
上传文件
创建密钥
保存密钥
"accessKey":"uBoubbhrhXhfw8iQhfMc"
"secretKey":"S6N7xkZme3wGHgd3Y6kKSpqKnYAQRkPfyPWR7Lo7"
Nginx 代理
- 负载均衡:将客户端请求平均分配到各个 MinIO 节点
- 统一入口:客户端只需知道 Nginx 服务器地址,无需关心后端具体节点
安装 Nginx 并启动
yum install -y nginx
systemctl enable nginx && systemctl restart nginx && systemctl status nginx
配置代理
vi /etc/nginx/conf.d/minio.conf
upstream minio_web{server 192.168.1.1:9001;server 192.168.1.2:9001;server 192.168.1.3:9001;
} server {listen 80;listen [::]:80;server_name _;location / {proxy_pass http://minio_web;proxy_set_header Host $http_host;client_max_body_size 1000m;}
}
- 仅需代理 Web UI 端口即可
- 简化访问:使用 80 端口(默认 HTTP 端口)访问 API 服务,无需指定端口
- 也可以根据实际情况代理为其他端口
重启 Nginx
systemctl restart nginx