当前位置: 首页 > news >正文

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        

测试代理访问地址

http://www.lryc.cn/news/613255.html

相关文章:

  • 【unitrix数间混合计算】2.1 数间混合计算模块(src/number/mod.rs)
  • ADC常用库函数(STC8系列)
  • 【面试向】大模型应用岗 —— Transformer 篇
  • 输电线路电气参数与阻抗计算全解析
  • 从库存一盘货到全域智能铺货:巨益科技全渠道平台助力品牌业财一体化升级
  • 从零开始掌握Hardhat开发
  • 【tips】css模仿矢量图透明背景
  • 小红书开源多模态视觉语言模型DOTS-VLM1
  • Ubuntu 22 下脚本登录MFA堡垒机
  • 嵌入式学习---在 Linux 下的 C 语言学习 Day10
  • 指针——练习
  • OLMo 2 架构深度解析:开放语言模型的技术革命
  • A Logical Calculus of the Ideas Immanent in Nervous Activity(神经网络早期的M-P模型)
  • 【数字图像处理系列笔记】Ch05:傅里叶变换与频率域滤波
  • 【实时Linux实战系列】实时分布式计算架构的实现
  • Mongodb常用命令简介
  • MongoDB学习专题(六)复制集和分片集群
  • 02电气设计-安全继电器电路设计(让电路等级达到P4的安全等级)
  • 内存泄漏系列专题分析之三十二:高通相机CamX ION/dmabuf内存管理机制CmdBuffer
  • VC6800智能相机:赋能智能制造,开启AI视觉新纪元
  • vue2+elementui select框可以选择可以回车添加新的option
  • Godot ------ 中级人物血条制作01
  • ElementUI之表格
  • Oracle 19C In-Memory 列存储技术测试
  • Renesas Electronics RA8M1语音套件(VK-RA8M1)
  • 深入解析Go设计模式:责任链模式实战
  • Electron 中 license-keys 的完整集成方案
  • 网络虚拟化是啥啊?
  • 自然语言处理×第四卷:文本特征与数据——她开始准备:每一次输入,都是为了更像你地说话
  • 拥抱云原生:从传统架构到云原生架构的演进与实践