基于Ubuntu系统,2台服务器使用Docker搭建MinIO集群及验证方法

MinIO集群简介

MinIO是一个高性能的分布式对象存储系统,兼容Amazon S3(Simple Storage Service)云存储服务的API。它支持横向扩展,提供高可用性和数据冗余,非常适合处理大量非结构化数据,如图片、视频、日志文件等。

为什么使用Docker搭建MinIO集群

使用Docker容器化技术搭建MinIO集群可以简化部署和管理过程,提高系统的可移植性和可扩展性。Docker容器的隔离性也使得每个MinIO节点的配置和管理变得更加简单。

环境准备

  • 两台Ubuntu服务器,已安装Docker环境。
  • 每台服务器上至少有两个数据目录用于MinIO的数据存储。

搭建步骤

步骤1:配置主机名解析

在两台服务器的/etc/hosts文件中添加对方的主机名解析:

复制代码
echo "192.168.1.101 minio-node1" | sudo tee -a /etc/hosts
echo "192.168.1.102 minio-node2" | sudo tee -a /etc/hosts

步骤2:创建Docker卷

在每台服务器上创建Docker卷用于数据存储:

复制代码
docker volume create minio-data1
docker volume create minio-data2

步骤3:启动MinIO服务

在每台服务器上使用Docker运行MinIO容器,并指定数据卷和网络模式:

复制代码
docker run -d --name minio \
  --restart=always --net=host \
  -e "MINIO_ROOT_USER=minioadmin" \
  -e "MINIO_ROOT_PASSWORD=minioadmin" \
  -v minio-data1:/data1 \
  -v minio-data2:/data2 \
  minio/minio server \
  --address ":9000" \
  http://minio-node1:9000/data1 http://minio-node1:9000/data2 \
  http://minio-node2:9000/data1 http://minio-node2:9000/data2

步骤4:验证集群状态

使用MinIO客户端工具mc来验证集群状态:

复制代码
mc alias set myminio http://minio-node1:9000 minioadmin minioadmin
mc admin info myminio

如果输出显示所有节点都已加入集群并且状态正常,说明集群搭建成功。

使用Python连接MinIO集群示例

安装MinIO Python客户端库

复制代码
pip install minio

Python代码示例

复制代码
from minio import Minio
from minio.error import S3Error

# 初始化MinIO Client
client = Minio(
    "minio-node1:9000",
    access_key="minioadmin",
    secret_key="minioadmin",
    secure=False
)

# 检查存储桶是否存在,不存在则创建
bucket_name = "my-bucket"
try:
    client.make_bucket(bucket_name)
except S3Error as exc:
    if exc.code != 'BucketAlreadyOwnedByYou':
        raise

# 上传文件
file_path = "/path/to/your/file"
try:
    client.fput_object(bucket_name, "object-name", file_path)
except S3Error as exc:
    print("Error occurred: ", exc)

# 列出存储桶中的文件
objects = client.list_objects(bucket_name)
for obj in objects:
    print(obj.object_name)

总结

通过上述步骤,我们成功在两台Ubuntu服务器上使用Docker搭建了MinIO集群,并使用Python进行了连接和操作的示例。这种部署方式不仅简化了配置和管理,还提高了系统的可扩展性和可靠性。MinIO集群的搭建和使用是处理大规模数据存储的有效解决方案。

相关推荐
薛慕昭20 分钟前
《从硬件到云端:STC8H ADC数据采集与华为物联网平台对接全解析》
服务器·物联网
weisian15121 分钟前
云原生--核心组件-容器篇-1-Docker和云原生关系(Docker是云原生的基石)
docker·云原生·容器
David爱编程36 分钟前
Service 与 Headless Service 全面对比与实战指南
docker·容器·kubernetes
巨懵1 小时前
不使用dockerfile的方式制作一个Ubuntu20.04的镜像
docker
一夜沐白1 小时前
Linux用户管理
linux·运维·服务器·笔记
PLUS_WAVE1 小时前
【Tools】chezmoi 跨多台不同的机器管理 dotfiles 的工具
linux·服务器·软件工程·工具·chezmoi
喝养乐多长不高2 小时前
详细PostMan的安装和基本使用方法
java·服务器·前端·网络协议·测试工具·https·postman
薯条不要番茄酱2 小时前
【网络原理】从零开始深入理解TCP的各项特性和机制.(二)
服务器·网络·tcp/ip
Pasregret3 小时前
备忘录模式:实现对象状态撤销与恢复的设计模式
运维·服务器·设计模式
LuckyRich13 小时前
【仿Mudou库one thread per loop式并发服务器实现】服务器边缘测试+性能测试
服务器·c++