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

news/2024/12/14 0:53:50/

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集群的搭建和使用是处理大规模数据存储的有效解决方案。


http://www.ppmy.cn/news/1554894.html

相关文章

高级java每日一道面试题-2024年12月12日-数据库篇-mysql 深度分页如何优化?

如果有遗漏,评论区告诉我进行补充 面试官: mysql 深度分页如何优化? 我回答: 在Java高级面试中,关于MySQL深度分页优化的提问,是一个考察数据库性能优化能力和对MySQL索引、查询机制理解深度的问题。以下是对MySQL深度分页优化的详细解答&#xff1a…

jQuery理论

jQuery定义 jQuery是一个快速、简洁的JavaScript库,它能够简化HTML文档遍历、事件处理、动画设计和Ajax交互。jQuery的设计目标是通过尽可能少的代码实现更多的功能,并且提供一种优雅的方式来处理HTML文档、处理事件、创建动画效果以及实现Ajax交互。. …

docker tdengine windows快速体验

#拉取镜像 docker pull tdengine/tdengine:2.6.0.34#容器运行 docker run -d --name td2.6 --restartalways -p 6030:6030 -p 6041:6041 -p 6043:6043 -p 6044-6049:6044-6049 -p 6044-6045:6044-6045/udp -p 6060:6060 tdengine/tdengine:2.6.0.34#容器数据持久化到本地 #/va…

速通前端篇 —— HTML

找往期文章包括但不限于本期文章中不懂的知识点: 个人主页:我要学编程程(ಥ_ಥ)-CSDN博客 所属专栏:速通前端 目录 HTML的介绍 如何创建HTML文件 HTML 文件基本结构 HTML常用标签 title标签 标题标签 h1-h6 段落标签 p 换行标签 b…

python数据采集-URL编码处理

1. 导入必要的库 - urllib.request:用于发送HTTP请求。 - urllib.parse:用于对URL进行编码。 - fake_useragent.UserAgent:用于生成随机的用户代理,模拟真实的浏览器行为。 - webbrowser:用于在浏览器中打开文…

ffmpeg使用自定义字体添加字幕

一,背景与问题描述 背景 最近工作项目要求,需要使用SRT字幕文件,为对应的视频添加字幕,并且需要使用指定的字体(如Roboto、Poppins等) 调研发现,使用以下命令可以为视频添加字幕 ffmpeg -i …

MacOS 下 pico/pico2 学习笔记

1.安装开发工具 cmake brew install cmakeopenocd brew install openocdarm-none-eabi-gcc 用 brew 安装的版本会出现如下错误: arm-none-eabi-gcc: fatal error: cannot read spec file nosys.specs: No such file or directory用 arm 官方的版本没有问题。 cd …

运输层4——TCP格式(重点!)

目录 一、TCP报文段格式 二、最大报文长度 MSS 一、TCP报文段格式 长度:前20个字节固定 后4n个字节(报文段格式不固定) 1、源端和目的端:各2个字节 作用:指明TCP链接的发送 2、序号 4字节 作用&#xff1…