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

使用 Docker 快速部署 MinIO 文件存储服务

使用 Docker 快速部署 MinIO 文件存储服务

在日常开发中,文件管理(如图片、视频、日志、数据集等)常面临分散存储、安全性低、运维复杂等问题,传统文件存储方式易引发上传漏洞等风险。MinIO 作为一款高性能、轻量级的对象存储服务,兼容 Amazon S3 协议,可集中管理分散对象,减少暴露面并降低运维成本,是解决文件存储痛点的理想选择。

快速部署 MinIO(Docker 方式)

1. 拉取 MinIO 镜像

推荐使用指定稳定版本镜像(避免 latest 版本的兼容性问题):

docker pull minio/minio:RELEASE.2025-04-22T22-12-26Z

版本号格式为 RELEASE.年-月-日T时-分-秒Z,可在 MinIO 官方镜像仓库 选择最新稳定版。

2. 启动 MinIO 容器

通过以下命令启动容器,实现数据持久化并映射端口:

docker run -d \--name minio-server \-p 9000:9000 \  # S3 兼容 API 端口(程序访问用)-p 9001:9001 \  # 管理控制台端口(Web 访问用)-v /home/admin/minio/data:/data \  # 挂载数据目录(持久化存储)-e "MINIO_ROOT_USER=adm1n" \  # 控制台登录用户名-e "MINIO_ROOT_PASSWORD=202019.Lvjin" \  # 控制台登录密码(生产环境建议复杂度更高)minio/minio server /data --console-address ":9001"  # 指定控制台监听端口

参数说明:

  • -d:后台运行容器;
  • --name:指定容器名称(便于后续管理);
  • -p 9000:9000:MinIO 的 S3 协议 API 端口,供程序(如客户端、编辑器)调用;
  • -p 9001:9001:Web 管理控制台端口,用于可视化操作(如创建桶、管理凭证);
  • -v:将宿主机目录 /home/admin/minio/data 挂载到容器内 /data,确保数据在容器重启后不丢失(需保证宿主机目录有读写权限);
  • -e:设置环境变量,指定管理员账号密码(生产环境需避免明文暴露)。

3. 访问 MinIO 控制台

启动成功后,通过浏览器访问 http://服务器IP:9001,使用上述 MINIO_ROOT_USERMINIO_ROOT_PASSWORD 登录:
MinIO 控制台登录页

核心操作:创建存储桶与访问凭证

3.1 创建存储桶(图形化操作)

存储桶(Bucket)是 MinIO 中管理对象的基本单位,类似文件夹。以“微信 Markdown 编辑器图片存储”为例:

  1. 登录控制台后,点击左侧菜单栏 BucketsCreate Bucket
  2. 输入桶名(如 wechat-markdown,需小写、无特殊字符);
  3. 按需配置权限(如允许公开访问需开启 Public Access,否则默认私有);
  4. 点击 Create Bucket 完成创建。

创建存储桶

3.2 生成访问凭证(Access Token)

程序(如编辑器)需通过访问凭证调用 MinIO API,步骤如下:

  1. 控制台左侧菜单栏点击 Access KeysCreate access key
  2. 输入描述(如 wechat-markdown-token),点击 Create
  3. 生成后会自动下载 JSON 文件(包含 accessKeysecretKey),secretKey 仅此时可见,需妥善保存(丢失需重新创建)。

创建访问凭证
下载凭证 JSON

JSON 文件内容示例:

{"url": "http://服务器IP:9000",  // 注意:应为 S3 API 端口(9000),非控制台端口"accessKey": "j1duKbN0DbWeoqwt0yEJ",  // 访问密钥"secretKey": "5Le9Q2kv4r53w8SuR5cVOVzTQT5OdMKDRASagBzz",  // 密钥(仅首次可见)"api": "s3v4",  // 签名算法版本(推荐 s3v4)"path": "auto"  // 路径样式(auto 自动适配)
}

微信 Markdown 编辑器配置

将 MinIO 配置到编辑器,实现图片直传存储桶:

  1. 打开微信 Markdown 编辑器,找到“图床设置”→“S3 兼容存储”;
  2. 按以下说明填写参数:
    • Endpoint:MinIO 的 S3 API 地址(如 http://服务器IP:9000);
    • Bucket:已创建的存储桶名(如 wechat-markdown);
    • Access Key:JSON 文件中的 accessKey
    • Secret Key:JSON 文件中的 secretKey
    • 其他参数保持默认(如 API 版本选 s3v4)。

编辑器配置

测试:上传图片并验证

  1. 在编辑器中插入图片,选择“上传到图床”;
  2. 上传成功后,图片会自动存储到 MinIO 对应桶中:

上传测试
桶中文件

  1. 访问图片:通过 URL http://服务器IP:9000/桶名/文件名 可直接访问(需确保桶权限允许公开访问)。

访问图片

注意事项

  1. 数据安全
    • 生产环境中,MINIO_ROOT_PASSWORD 和访问凭证需使用强密码,并避免明文存储;
    • 重要文件的存储桶建议关闭公开访问,通过签名 URL 临时授权访问。
  2. 端口与网络
    • 若需外部访问,需确保服务器防火墙开放 9000(API)和 9001(控制台)端口;
    • 公网环境建议通过 HTTPS 访问(可配置 Nginx 反向代理并添加 SSL 证书)。
  3. 数据备份:定期备份挂载的 /home/admin/minio/data 目录,避免数据丢失。
  4. 性能优化:大文件场景可调整 MinIO 的纠删码模式(默认单节点单盘,生产建议多盘冗余)。
http://www.jsqmd.com/news/37869/

相关文章:

  • 2025 年 11 月财税合规服务厂家推荐排行榜,电商/跨境电商/出口退税/公司注销/股权设计/平台报送/亚马逊/Temu/速卖通/高新企业/审计报告全案解决方案
  • AI智能体落地:Agent-Assist vs 全自动化完整决策指南
  • 详细介绍:微服务时代的前后端协作:API契约驱动开发实践
  • ZROI-NOIP2025做题记录
  • week1--RE--刷题记录
  • Appium Inspector教程
  • Pycharm常用设置
  • pythontip 映射字符串中的字母
  • Python : argument name should be lowercase 警告处理解决方法
  • *题解:P5278 算术天才⑨与等差数列
  • instanceof(类型)
  • 高级程序语言设计第5次
  • 25.11.11 spfa算法
  • 什么是glTF,与glb的区别,规格和优点,通俗易懂地解释下载获取
  • CF2164E Journey 题解
  • 算法训练之BFS解决最短路径难题
  • ASP.NET Core Authorization: 跳过JWT校验
  • 学习昇腾硬件软件产品名称
  • 实用指南:[linux仓库]信号保存[进程信号肆]
  • v4l2_subdev和video_device区分
  • 第七天 设计用例方法
  • AT_agc034_c [AGC034C] Tests
  • 论安慰人
  • 电商运营每天在忙啥?拆解4个核心工作,新手也能照做 - 智慧园区
  • 102302112王光诚作业2
  • 详细介绍:LLaMA-Factory实战优化进阶
  • ch3题解
  • 2025年11月全日制艺考生文化课新推荐:聚焦全日制艺考生文化课培训/全日制艺考生文化课机构/核心考点攻坚与沉浸式教学
  • 2025年11月镀锌板品牌新榜:聚焦HC300DPD+Z镀锌板//镀锌花纹板/热镀锌花纹板/Q345B镀锌花纹板全产业链优势!
  • [随笔]关于意识形态