搭建高可用MinIO集群

这篇具有很好参考价值的文章主要介绍了搭建高可用MinIO集群。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

引言:我为什么要写这篇文档,因为MinIO在国内的资料比较少,但是在国外社区还是比较活跃的。从刚开始接触MinIO是因为集团要搭建文件服务系统供整个集团大大小小几百个项目组去使用,所以最终肯定奔着高可用目标去掉的。刚开始接触MinIO的时候,第一步肯定是进行一个环境的搭建,不管是测试环境,还是开发环境,甚至于生产环境,要求是一个比一个高,从单集群到多集群再到两地三中心、三地五中心。但是国内搭建的资料很少,且在CSDN上,保守来说至少50%的搭建是错误的(比如:用mkdir来充作Drive,用CI=true来忽略minio对于磁盘的检查等等),所以这里给大家看看我是如何搭建一个标准的MinIO最小集群。
看过官网的快速开始文档的应该知道,MinIO高可用集群至少满足四个节点才能开启纠删码模式,所以今天我的目标是用vm搭建一个四节点十六个Drive的最低配高可用MinIO集群。(这边我默认咱们都有MinIO基础知识了啊,比如纠删码、Set、node、drive等等)

一、准备工作

首先,我会用虚拟机创建四个节点,每个节点20G的初始流量,在创建了四个初始节点后,会根据标准的磁盘挂载的方式去对每个节点挂载四块5G总共20G的磁盘(因为minio要求作为存储的磁盘一定是要干净的,所以这边选择磁盘挂载的方式进行,我司也是这么做的),这样子我我们可以得到四个节点总共80G的底层存储空间

ip 名称
192.168.192.163 minio-1
192.168.192.164 minio-2
192.168.192.165 minio-3
192.168.192.166 minio-4
192.168.192.167 minio-nginx(负载)

1、初始系统环境搭建

image.png
image.png
image.png
这边我内存稍微选大一点,这样操作的时候会更流畅,你们生产肯定是怎么高怎么来呗,我们测试环境单节点至少都是64G内存起步,生产更高(高得多)
image.png
image.png
image.png
等待初始系统安装
image.png
这边就安装好了,然后我们选择克隆的方式(我偷懒)克隆出另外三台机器,minio-2、minio-3、minio-4
image.png
image.png
image.png
image.png
image.png
重复整个克隆操作,克隆出minio-3、minio-4
image.png
这样我们四台机器就创建好了

2、命令行工具链接

这边启动四台机器,使用ip addr命令分别获取机器的ip地址,使用命令行工具进行连接,我这边使用的Xshell7个人版
image.png
具体的ip可以开头的表格

3、关闭防火墙

这一步其实看情况啦,公司的防火墙肯定不给关的,顶多开放固定端口,我这边直接用开放固定端口的形式了,虽然这样会麻烦一点,因为你不知道涉及哪些端口的话,后面容易出问题,minio主要是9000和9001端口,这是官方默认的端口。9000是minio-server的端口,9001是minio-cosole的端口,console空就是一个web可视化界面啦。这边把怎么开放端口的命令贴出来

## 查看防火墙状态
systemctl status firewalld 

image.png
我这边是开启的哈

## 给9000添加永久开放端口
[root@localhost ~]# firewall-cmd --zone=public --add-port=9000/tcp --permanent
success

## 给9001添加永久开放端口
[root@localhost ~]# firewall-cmd --zone=public --add-port=9001/tcp --permanent
success
[root@localhost ~]# 

## 重启防火墙
[root@localhost ~]# firewall-cmd --reload
success

## 检查是否添加成功
[root@localhost ~]# firewall-cmd --zone=public --list-port
9000/tcp 9001/tcp


以上操作在另外三台机器也运行
image.png

4、挂载磁盘

关闭四台虚拟机,依然会用minio-1为例子来进行挂载演示
image.pngimage.pngimage.pngimage.pngimage.pngimage.pngimage.pngimage.png
这样就给这台minio-1添加一块磁盘,但是整个时候并没有挂载到目录上哦,我们先不急,先把剩下的三块盘装完,依旧是重复上面的动作
image.pngimage.png
这样minio-1的四块磁盘就先准备好了

然后分别把minio-2、minio-3、minio-4也创建出四块预先分配的磁盘
image.pngimage.pngimage.png

现在我们的四台机器都已经创建好资源了,我们接下来要做的就是把这些创建的磁盘挂载到文件目录上去

打开四台虚拟机,使用xshell,我们开始要敲命令了

输入fdisk -l命令查看当前系统磁盘分区。
image.png
这块就是我们额外增加的四个磁盘,名称为sdb、sdc、sdd、sde

我们首先分别将这四块盘格式化为xfs格式

[root@localhost ~]# mkfs.xfs /dev/sdb -L DISK1
meta-data=/dev/sdb               isize=512    agcount=4, agsize=327680 blks
         =                       sectsz=512   attr=2, projid32bit=1
         =                       crc=1        finobt=0, sparse=0
data     =                       bsize=4096   blocks=1310720, imaxpct=25
         =                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0 ftype=1
log      =internal log           bsize=4096   blocks=2560, version=2
         =                       sectsz=512   sunit=0 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0
[root@localhost ~]# mkfs.xfs /dev/sdc -L DISK1
meta-data=/dev/sdc               isize=512    agcount=4, agsize=327680 blks
         =                       sectsz=512   attr=2, projid32bit=1
         =                       crc=1        finobt=0, sparse=0
data     =                       bsize=4096   blocks=1310720, imaxpct=25
         =                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0 ftype=1
log      =internal log           bsize=4096   blocks=2560, version=2
         =                       sectsz=512   sunit=0 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0
[root@localhost ~]# mkfs.xfs /dev/sdd -L DISK1
meta-data=/dev/sdd               isize=512    agcount=4, agsize=327680 blks
         =                       sectsz=512   attr=2, projid32bit=1
         =                       crc=1        finobt=0, sparse=0
data     =                       bsize=4096   blocks=1310720, imaxpct=25
         =                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0 ftype=1
log      =internal log           bsize=4096   blocks=2560, version=2
         =                       sectsz=512   sunit=0 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0
[root@localhost ~]# mkfs.xfs /dev/sde -L DISK1
meta-data=/dev/sde               isize=512    agcount=4, agsize=327680 blks
         =                       sectsz=512   attr=2, projid32bit=1
         =                       crc=1        finobt=0, sparse=0
data     =                       bsize=4096   blocks=1310720, imaxpct=25
         =                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0 ftype=1
log      =internal log           bsize=4096   blocks=2560, version=2
         =                       sectsz=512   sunit=0 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0

创建文件夹作为挂载源

mkdir /minio1
mkdir /minio2
mkdir /minio3
mkdir /minio4

image.png
使用mount进行挂载

[root@localhost /]# mount /dev/sdb /minio1
[root@localhost /]# mount /dev/sdc /minio2
[root@localhost /]# mount /dev/sdd /minio3
[root@localhost /]# mount /dev/sde /minio4

输入df -h命令检查挂载状态
image.png
mount挂载有风险,如果节点宕机重启或者因为其他因素重启,挂载就会消失,所以我们需要设置开机自动挂载
vim /etc/fstab
image.png

/dev/sdb                                  /minio1                 xfs     defaults,noatime 0 2
/dev/sdc                                  /minio2                 xfs     defaults,noatime 0 2
/dev/sdd                                  /minio3                 xfs     defaults,noatime 0 2
/dev/sde                                  /minio4                 xfs     defaults,noatime 0 2

输入reboot重启

image.png
重启之后依然是ok的

根据上面挂载的步骤,将其他三个节点的挂载一一配置好

题外话:这种挂载由很多种方式,有的是UUID,有的用LABEL=DISK1这种,只要你能挂的上,都没问题

paas:写到这里突然想到一个问题,我这刚安装的系统的时间肯定不对,到时候minio-console的上面显示的时间肯定不对,你们生产环境肯定有ntp同步时间啦,我这边就懒得做了,知道就行。

二、搭建

1、下载minio

## 普通x86的机器
wget https://dl.min.io/server/minio/release/linux-amd64/archive/minio-20230210184839.0.0.x86_64.rpm -O minio.rpm

## 苹果m1 m2的
wget https://dl.min.io/server/minio/release/linux-arm64/archive/minio-20230210184839.0.0.aarch64.rpm -O minio.rpm

如果是离线操作,直接去官网下载二进制文件安装就好了
image.png
等待下载完成
image.png下载完成

rpm -i minio.rpm

文件安装的位置默认是/usr/local/bin
image.png
我信了官网个鬼
image.png
这个老外毒奶粉玩家这条命令不行,还是我的好用(毒奶粉玩家我猜的)

2、配置service

这一步是为了让我们后面可以直接使用systemctl start minio这样的方式启动
如果你是跟我我上面安装的,会自动生成minio.servie文件的

vim /etc/systemd/system/minio.service

[Unit]
Description=MinIO
Documentation=https://docs.min.io
Wants=network-online.target
After=network-online.target
AssertFileIsExecutable=/usr/local/bin/minio

[Service]
WorkingDirectory=/usr/local

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=1048576

# 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})

官网版本:

[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

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})

如果是二进制版本安装的兄弟,把自己去创建这个文件/etc/systemd/system/minio.service,然后把上面这段复制进去

上面这些参数信息,我们只需要关注几个

  • WorkingDirectory:工作目录
  • EnvironmentFile: 变量文件,minio-server启动的时候,会去这个文件里面读取配置文件(这个我们一会需要修改)
  • User/Group:运行minio-server的用户

我好像还没有创建运行的用户,现在创建一个把,也不晚

[root@localhost bin]# groupadd -r minio-user
[root@localhost bin]# useradd -M -r -g minio-user minio-user
[root@localhost bin]# chown minio-user:minio-user /minio1 /minio2 /minio3 /minio4

3、修改环境变量文件

同样,如果是根据我上面安装的,这个变量文件会自己生成,如果是二进制安装包安装的,需要自己去创建这个文件,然后补充信息(根据安装包的版本,也会有差异,我目前遇到过,就算不是二进制这个文件也不存在的情况,到时候兄弟们遇上了就直接把下面的配置copy进去就好了)

vim /etc/default/minio

我先把官网的贴出来,二进制安装的兄弟们,直接把这个内容复制到自己创建的文件就好了

# Set the hosts and volumes MinIO uses at startup
# The command uses MinIO expansion notation {x...y} to denote a
# sequential series.
#
# The following example covers four MinIO hosts
# with 4 drives each at the specified hostname and drive locations.
# The command includes the port that each MinIO server listens on
# (default 9000)

MINIO_VOLUMES="https://minio{1...4}.example.net:9000/mnt/disk{1...4}/minio"

# Set all MinIO server options
#
# The following explicitly sets the MinIO Console listen address to
# port 9001 on all network interfaces. The default behavior is dynamic
# port selection.

MINIO_OPTS="--console-address :9001"

# Set the root username. This user has unrestricted permissions to
# perform S3 and administrative API operations on any resource in the
# deployment.
#
# Defer to your organizations requirements for superadmin user name.

MINIO_ROOT_USER=minioadmin

# Set the root password
#
# Use a long, random, unique string that meets your organizations
# requirements for passwords.

MINIO_ROOT_PASSWORD=minio-secret-key-CHANGE-ME

# Set to the URL of the load balancer for the MinIO deployment
# This value *must* match across all MinIO servers. If you do
# not have a load balancer, set this value to to any *one* of the
# MinIO hosts in the deployment as a temporary measure.
MINIO_SERVER_URL="https://minio.example.net:9000"

接下来我们对这个文件进行一些变动

# Set the hosts and volumes MinIO uses at startup
# The command uses MinIO expansion notation {x...y} to denote a
# sequential series.
#
# The following example covers four MinIO hosts
# with 4 drives each at the specified hostname and drive locations.
# The command includes the port that each MinIO server listens on
# (default 9000)
## 这块是文件磁盘的位置 因为我们是集群节点是163-166 这边是一种池化写法
MINIO_VOLUMES="http://192.168.192.16{3...6}:9000/minio{1...4}"

# Set all MinIO server options
#
# The following explicitly sets the MinIO Console listen address to
# port 9001 on all network interfaces. The default behavior is dynamic
# port selection.

## minio-console的地址 就是web界面控制台
MINIO_OPTS="--console-address :9001"

# Set the root username. This user has unrestricted permissions to
# perform S3 and administrative API operations on any resource in the
# deployment.
#
# Defer to your organizations requirements for superadmin user name.

# console的登陆账号
MINIO_ROOT_USER=minioadmin

# Set the root password
#
# Use a long, random, unique string that meets your organizations
# requirements for passwords.

# console的登陆密码
MINIO_ROOT_PASSWORD=minioadmin

# Set to the URL of the load balancer for the MinIO deployment
# This value *must* match across all MinIO servers. If you do
# not have a load balancer, set this value to to any *one* of the
# MinIO hosts in the deployment as a temporary measure.
# 负载均衡地址 如果没有负载均衡就不要放开这个配置
#MINIO_SERVER_URL="http://192.168.192.163:9000"

然后在其他三台机器依次安装,并修改/etc/default/minio环境变量文件

如果你们公司有自己的域名映射的话,你们就走域名咯,如果域名不连贯的话(建议还是连贯),可以分开配置

MINIO_VOLUMES="http://192.168.192.163:9000/minio{1...4} http://192.168.192.155:9000/minio{1...4}"

参考以上格式,用空格分隔,我只写了两个节点

三、启动

systemctl start minio

四个节点依次运行
image.pngimage.pngimage.pngimage.png
不吹不黑,一条龙通关

浏览器访问任意一节点的9001端口
image.png
密码:minioadmin/minioadmin
image.png
查看下监控信息,确保所有服务已启动
image.png
四个节点总共16快挂载的磁盘,
image.png
每块盘5GB,没错

四、使用负载均衡器

这里选用nginx来作为负载均衡,会另外使用一台机器,提供统一的入口,然后将请求分发到这四个节点的9000端口
nginx版本:nginx-1.20.2.tar.gz
够用就行
image.pngimage.png
image.pngimage.png
嘿,哥们电脑配置还行,随便奢侈一把,我32G 三星DDR5内存
image.png
等待安装

一会我们会监听nginx的机器的9000端口 转发到四台服务上

image.png

安装成功了,我先配置一下Xshell
image.png
传输nginx安装包image.png
解压

tar -zxvf nginx-1.20.2.tar.gz

image.png
安装一下

//一键安装上面四个依赖
yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel

image.png
进入nginx目录,使用nginx默认配置

./configure

image.png完成!

编译安装

make
make install

查找安装路径

whereis nginx

image.png

修改ngix配置文件

vim /user/loal/nginx/conf/nginx.conf
worker_processes  1;

events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    sendfile        on;
    
    keepalive_timeout  65;

    upstream minio_server {
			server	192.168.192.163:9000;
			server  192.168.192.164:9000;
			server  192.168.192.165:9000;
			server  192.168.192.166:9000;
    }

    upstream minio_console {
			server 192.168.192.163:9001;
			server 192.168.192.164:9001;
			server 192.168.192.165:9001;
			server 192.168.192.166:9001;
    }


    server {
        listen       9000;
        server_name  localhost;

        location / {
            proxy_pass http://minio_server;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
  	server {
        listen       9001;
        server_name  localhost;

        location / {
            proxy_pass http://minio_console;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

    }
}

访问192.168.192.167:9001端口
image.png
哦对了,这个负载均衡的机器记得把9000和9001端口打开,参考上面

五、测试

1、创建bucket

image.png

2、upload

image.png

3、download

image.png

六、留个坑

关于ng配置这块,因为涉及到文件上传下载等,还需要配置文件流以及大小的配置哦。文章来源地址https://www.toymoban.com/news/detail-821877.html

到了这里,关于搭建高可用MinIO集群的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 高性能分布式对象存储——MinIO实战操作(MinIO扩容)

    MinIO的基础概念和环境部署可以参考我之前的文章:高性能分布式对象存储——MinIO(环境部署) 官方文档:https://docs.min.io/docs/minio-admin-complete-guide.html MinIO Client (mc) 为 UNIX 命令(如 ls、cat、cp、mirror、diff、find 等)提供了现代替代方案。它支持文件系统和兼容 Amazon S3 的云存

    2023年04月26日
    浏览(47)
  • 打造自己的分布式MinIO对象存储

    MinIO是一个对象存储解决方案,它提供了一个与Amazon Web Services S3兼容的API,并支持所有核心S3特性。MinIO旨在部署在任何地方——公共云或私有云、裸机基础架构、协调环境和边缘基础架构。 分布式MinIO如何工作 Server Pool由多个Minio服务节点与其附属的多个磁盘构成。MinIO支持

    2024年02月11日
    浏览(45)
  • Springboot整合minio组件-分布式文件存储

    一、快速开始 Minlo说明: Minio是Apcche旗下的一款开源的轻量级文件服务器,基于对象存储,协议是基于Apache License v2.0,开源可用于商务。 Minio主要用来存储非结构化的数据,类似文件,图片,照片,日志文件,各类备份文件等,按照官网描述,文件的大小从几KB到5TB。 Minio提

    2024年02月11日
    浏览(41)
  • minio分布式集群安装部署实战详细手册

    Minio是GlusterFS创始人之一Anand Babu Periasamy发布新的开源项目。基于Apache License v2.0开源协议的对象存储项目,采用Golang实现,客户端支Java,Python,Javacript, Golang语言。 其设计的主要目标是作为私有云对象存储的标准方案。主要用于存储海量的图片,视频,文档等。非常适合于存储

    2024年02月12日
    浏览(30)
  • 使用docker搭建minio分布式对象存储系统

    这里我简单的和大家介绍一下什么是minio ? 附上Minio官网链接:https://minio.org.cn/ MinIO是一种开源的对象存储服务器,通过使用标准的HTTP/REST API来访问和管理数据。它采用分布式架构,具有高性能、高可用性和可扩展性。MinIO可以帮助用户轻松管理和存储大量的非结构化数据,

    2024年02月12日
    浏览(44)
  • OSS文件上传、MinIO分布式文件存储系统

    阿里云OSS上传图片 实现步骤: 1. 定义OSS相关配置 application-dev.yml application.yml 2. 读取OSS配置 在sky-common模块中,已定义 3. 生成OSS工具类对象 在sky-server模块 其中,AliOssUtil.java已在sky-common模块中定义 4. 定义文件上传接口 在sky-server模块中定义接口 MinIO分布式文件存储系统 MinI

    2024年01月24日
    浏览(37)
  • 常用分布式文件系统(对象存储)对比-SeaweedFS、Minio

    常用分布式文件系统,相对比较热门的有Minio,SeaweedFS,FastDFS,ceph。主要对比一下Minio,SeaweedFS。 什么是SeaweedFS? SeaweedFS是一种简单的、高度可扩展的分布式文件系统。SeaweedFS是一个非常优秀的由 Go语言开发的分布式存储开源项目。它是用来存储文件的系统,并且与使用的语言无

    2024年02月03日
    浏览(43)
  • 【分布式文件存储】MinIO部署及实现文件上传下载

    目录 概述 MinIO集群部署 准备docker-compose.yml 测试启动 MinIO用户管理 Buckets管理  创建Buckets MinIO客户端 引入依赖   文件上传下载Demo 调用API碰到的问题 MinIO | 高性能, Kubernetes 原生对象存储 MinIO是全球领先的对象存储先锋,目前在全世界有数百万的用户。 高性能 ,在标准硬件

    2024年02月07日
    浏览(46)
  • Linux 部署 MinIO 分布式对象存储 & 配置为 typora 图床

    MinIO 是一款高性能的对象存储系统,它可以用于大规模的 AI/ML、数据湖和数据库工作负载。它的 API 与Amazon S3 云存储服务完全兼容,可以在任何云或本地基础设施上运行。MinIO 是 开源软件 ,也提供商业许可和支持 MinIO 的特点有: 简单 :MinIO 的安装和使用都非常简单,只需

    2024年02月07日
    浏览(47)
  • 云原生 | 从零开始,Minio 高性能分布式对象存储快速入手指南

    [ 点击 👉 关注「 全栈工程师修炼指南」公众号 ] 希望各位看友多多支持【关注、点赞、评论、收藏、投币】,助力每一个梦想。 【 WeiyiGeek Blog\\\'s - 花开堪折直须折,莫待无花空折枝  】 作者主页: 【 https://weiyigeek.top 】 博客地址: 【 https://blog.weiyigeek.top 】 作者答疑学习交

    2024年02月08日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包