Docker安装MinIO对象存储中间件

MinIO 是一个高性能、分布式的对象存储系统,兼容 Amazon S3 云存储服务协议,广泛应用于企业存储、大数据、机器学习和容器化应用等领域。以下是详细介绍:

核心特点

  • 兼容 S3 API :全面兼容 Amazon S3 API,这意味着使用 S3 API 的应用程序几乎无需修改即可与 MinIO 兼容,方便用户迁移和集成。

  • 高性能 :MinIO 支持分布式架构,可将多个服务器组合成一个存储池,提供高吞吐量和低延迟的存储服务,适用于高性能计算和大数据处理场景。

  • 分布式架构 :支持在多个节点上进行分布式存储,能够充分利用多台机器的资源,实现存储容量和性能的水平扩展。

  • 安全性 :支持多种身份验证和授权机制,包括 S3 签名验证、主动式目录服务(Active Directory)和轻量级目录访问协议(LDAP)等,还支持数据加密、多因素身份验证等安全功能,确保数据的安全性和隐私性。

  • 易用性 :提供丰富的客户端工具和管理界面,方便用户进行存储操作和管理。同时,其安装和配置过程简单,便于快速部署和使用。

搭建过程

环境准备

1、安装Docker

2、创建维护用户和存储目录

如果不使用Docker的 Rootless部署,可以不创建普通用户,在docker run启动时,也无需--user指定运行用户。

bash 复制代码
useradd minio && usermod -a -G docker minio
su - minio && mkdir -p ${HOME}/minio/data

启动MinIO容器

bash 复制代码
docker run -d --name my-minio \
   -p 9000:9000 \
   -p 9001:9001 \
   --user $(id -u):$(id -g) \
   quay.io/minio/minio server /data --console-address ":9001"

注意:

1、MinIO默认情况下在随机端口上运行控制台,如果您希望选择特定的端口,

请使用--console-address来选择特定的接口和端口。

2、不指定用户名密码,可以通过docker logs从日志中查看用户名密码,默认:minioadmin:minioadmin

其他额外启动项

指定用户名密码

-e "MINIO_ROOT_USER=admin" \

-e "MINIO_ROOT_PASSWORD=PASSWORD" \

配置console语言为中文。

虽并未对console web页做国际化,仍然显示英文;但是,部分配置项会以中文展示了。

-e "MINIO_CONSOLE_LOCALE=zh_CN" \

以本地目录配置存储持久化

-v ${HOME}/minio/data:/data \

配置https访问所需的证书目录

**注:**这里不指定,默认使用~/.minio/certs目录下的证书(该目录下默认为空,即使用http访问)

-v ${HOME}/minio/certs:/certs \

基本启动参数

  • docker run -d --name my-minio3 :以分离模式(后台运行)启动一个名为 my-minio3 的 Docker 容器。

  • -p 9000:9000 -p 9001:9001 :将宿主机的 9000 端口和 9001 端口分别映射到容器内部的 9000 端口和 9001 端口。9000 用于对象存储服务,9001 用于 MinIO Console。

  • --user $(id -u):$(id -g) :以当前用户的用户 ID 和组 ID 运行容器,确保容器内的文件和目录权限与宿主机用户匹配,避免权限问题。

环境变量配置

  • -e "MINIO_ROOT_USER=admin" :设置 MinIO 的根用户账号为 admin

  • -e "MINIO_ROOT_PASSWORD=你的密码" :设置 MinIO 的根用户密码。

  • -e "MINIO_CONSOLE_LOCALE=zh_CN" :设置 MinIO Console 的语言为中文(简体)。

卷挂载

  • -v ${HOME}/minio/data:/data :将宿主机用户主目录下的 minio/data 目录挂载到容器内的 /data 目录,用于存储 MinIO 的数据。

  • -v ${HOME}/minio/certs:/certs :将宿主机用户主目录下的 minio/certs 目录挂载到容器内的 /certs 目录,用于提供 TLS 证书和私钥。

MinIO 服务配置

  • quay.io/minio/minio server --certs-dir /certs /data --console-address ":9001" :指定使用的 MinIO 镜像,并配置 MinIO 服务。

    • server :表示以服务器模式运行 MinIO。

    • --certs-dir /certs :指定证书目录为容器内的 /certs,用于启用 HTTPS。

    • /data :指定 MinIO 数据存储目录为容器内的 /data

    • --console-address ":9001" :设置 MinIO Console 的监听地址为容器内部的 9001 端口。

最终启动命令

bash 复制代码
docker run -d --name my-minio3 \
   -p 9000:9000 \
   -p 9001:9001 \
   --user $(id -u):$(id -g) \
   -e "MINIO_ROOT_USER=admin" \
   -e "MINIO_ROOT_PASSWORD=PASSWORD" \
   -e "MINIO_CONSOLE_LOCALE=zh_CN" \
   -v ${HOME}/minio/data:/data \
   -v ${HOME}/minio/certs:/certs \
   quay.io/minio/minio server --certs-dir /certs /data --console-address ":9001"

如果只启动S3 API的话,要禁用console,可以如下启动:

bash 复制代码
docker run -d --name my-minio2 \
   -p 9000:9000 \
   --user $(id -u):$(id -g) \
   -e "MINIO_BROWSER=off" \
   -v ${HOME}/minio/data:/data \
   quay.io/minio/minio server /data

验证

使用MinIO控制台进行测试

MinIO服务器带有一个嵌入式的基于web的对象浏览器。

浏览器访问:http://IP:9000

用户名密码登录后

相关推荐
Akamai中国1 小时前
GPU加速Kubernetes集群助力音视频转码与AI工作负载扩展
人工智能·云原生·容器·kubernetes·云计算·音视频
珊珊而川1 小时前
docker常用指令
运维·docker·容器
迷雾骑士4 小时前
CentOS Stream安装MinIO教程
centos·minio
shane-u4 小时前
【已解决】docker search --limit 1 centos Error response from daemon
docker·容器·centos
todoitbo5 小时前
开源一个记账软件,支持docker一键部署
运维·docker·容器·开源·springboot·记账软件·容器部署
安顾里5 小时前
什么是endpoints?
运维·容器·kubernetes
运维小文5 小时前
fluentd采集K8S日志
云原生·容器·kubernetes·fluentd·efk
qq_2153978978 小时前
docker 启动一个python环境的项目
docker·容器
安顾里9 小时前
k8s-ServiceAccount 配置
云原生·容器·kubernetes