news 2026/5/1 7:22:52

使用 Docker 快速搭建 MinIO 文件存储服务

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用 Docker 快速搭建 MinIO 文件存储服务

在日常开发中,我们经常需要处理文件上传、下载、存储与访问的场景,比如图片、视频、日志文件、模型数据集等。传统的文件系统难以满足高并发、分布式部署以及云原生化的需求。而 MinIO 作为一款高性能、轻量级、兼容 Amazon S3 协议的对象存储服务,正是为此而生。

本文将带你从零开始,通过 Docker 部署 MinIO 服务,并结合 Java SDK 实现文件的上传与访问。

无论你是想在本地搭建一个轻量文件中心,还是为企业内部系统构建一个可扩展的对象存储方案,这篇文章都能帮你快速上手。

1 拉取 Minio 镜像

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

2 启动 Minio 容器

我们假设你希望访问端口为 9000(API)和 9001(Web 控制台),可以这样运行:

docker run -d \

--name minio \

-p 9000:9000 \

-p 9001:9001 \

-v /Users/zhangyong/docker/minio/data:/data \

-v /Users/zhangyong/docker/minio/config:/root/.minio \

-e "MINIO_ROOT_USER=admin" \

-e "MINIO_ROOT_PASSWORD=admin123456" \

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

server /data --console-address ":9001"

01 参数说明

-p 9000:9000:MinIO API 服务端口

-p 9001:9001:Web 控制台端口

-v /Users/zhangyong/docker/minio/data:/data:映射数据目录

-v /Users/zhangyong/docker/minio/config:/root/.minio:保存配置

MINIO_ROOT_USER、MINIO_ROOT_PASSWORD:管理员账号密码

server /data --console-address ":9001":指定数据目录并启用控制台端口

02 启动后访问

控制台地址:http://localhost:9001

登录账号:admin

登录密码:admin123456

3 上传文件

在 MinIO(以及所有兼容 S3 的对象存储系统)中,桶(Bucket) 是最顶层的逻辑存储单元,可以理解为一个“命名空间”或“大文件夹”,它是所有对象(文件)的容器。

MinIO 不存在真正的目录结构,而是通过对象 key 的前缀来模拟目录层级。

例如,我们可以创建一个 bucket 叫 datasets ,数据集下面的文件对象如下:

datasets/

├── mydataset1/

│ ├── train/image1.jpg

│ └── train/image2.jpg

└── mydataset2/

├── data.csv

└── labels.txt

虽然看起来像目录树,但实际上存储系统中只有对象:

datasets/mydataset1/train/image1.jpg

datasets/mydataset1/train/image2.jpg

datasets/mydataset2/data.csv

datasets/mydataset2/labels.txt

MinIO 客户端(mc)或 SDK(Java/Python)在列举对象时,会自动把这些前缀识别为“目录”。

接下来,我们按照流程上传文件。

1、创建桶 datasets

2、创建新路径 mydataset1

3、上传图片

4 访问授权

1、修改桶的访问策略

图中,我们需要将访问策略从 Private 修改成 Public 。

2、访问图片

MinIO 地址:http://localhost:9000

桶名:datasets

对象路径:mydataset1/父与女.png

因为桶已经设置为 Public ,所以我们可以直接访问如下的链接即可:

5 Java 示例

01 创建 Access Key

02 Minio 上传示例

1、添加依赖

<dependency>

<groupId>io.minio</groupId>

<artifactId>minio</artifactId>

<version>8.5.10</version>

</dependency>

2、编写代码

public class MinioUnitTest {

public static void main(String[] args) {

try {

// 1. 初始化 MinIO 客户端

MinioClient minioClient = MinioClient.builder()

.endpoint("http://localhost:9000") // MinIO 地址

// accessKey 和 secretKey

.credentials("yHxFBiulXKsuhbg9nHqO", "qmsQU4JuWuwlr3ZgY4eMFbQ9LaTzzEHMV6T722kC")

.build();

// 2. 文件信息

String bucketName = "datasets";

String objectName = "mydataset1/images/xiaoyuanjiang.webp"; // 上传路径(类似目录)

String filePath = "/Users/zhangyong/Pictures/xiaoyuanjiang.webp"; // 本地文件路径

// 3. 上传文件(流式上传)

try (InputStream in = new FileInputStream(filePath)) {

minioClient.putObject(

PutObjectArgs.builder()

.bucket(bucketName)

.object(objectName)

.stream(in, in.available(), -1)

.contentType("image/png") // 可根据文件类型设置

.build()

);

System.out.println("✅ 文件上传成功: " + objectName);

}

// 4. 拼接直链 URL(因为是 public bucket)

String publicUrl = String.format("http://localhost:9000/%s/%s", bucketName, objectName);

System.out.println("✅ 上传成功,直链地址:");

System.out.println(publicUrl);

// // 4. 生成临时访问链接(可选)

// String url = minioClient.getPresignedObjectUrl(

// GetPresignedObjectUrlArgs.builder()

// .method(Method.GET)

// .bucket(bucketName)

// .object(objectName)

// .expiry(60 * 60) // 1小时有效

// .build()

// );

// System.out.println("📎 临时访问地址: " + url);

} catch (Exception e) {

e.printStackTrace();

}

}

}

3、执行效果

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 12:55:30

C语言goto语句深入解析:合理使用规避陷阱,让代码更高效

掌握goto的正确使用场景&#xff0c;避免滥用导致的代码混乱在C语言编程中&#xff0c;"goto"语句是最具争议性却又无法被完全替代的特性之一。本文将全面介绍"goto"语句的定义、应用场景、常见错误及解决方法&#xff0c;帮助初学者正确理解并合理使用这一…

作者头像 李华
网站建设 2026/4/23 11:01:05

SpringBoot3高效数据权限控制实战

前言你是否苦恼于在 Spring Boot3 项目中&#xff0c;数据权限控制难以高效实现&#xff1f;在当今互联网软件开发领域&#xff0c;数据安全至关重要&#xff0c;而高效的数据权限控制则是保障数据安全的关键环节。对于从事互联网软件开发的人员来说&#xff0c;在 Spring Boot…

作者头像 李华
网站建设 2026/4/30 13:21:17

Windows安全组件终极管理指南:2025年系统性能优化完整方案

Windows安全组件终极管理指南&#xff1a;2025年系统性能优化完整方案 【免费下载链接】windows-defender-remover 项目地址: https://gitcode.com/gh_mirrors/win/windows-defender-remover 在Windows系统日常使用中&#xff0c;许多用户面临着安全组件过度占用系统资…

作者头像 李华
网站建设 2026/5/1 6:53:05

LFM2-700M:Liquid AI重新定义边缘智能终端部署标准

导语 【免费下载链接】LFM2-700M-GGUF 项目地址: https://ai.gitcode.com/hf_mirrors/LiquidAI/LFM2-700M-GGUF Liquid AI推出新一代边缘智能模型LFM2-700M&#xff0c;通过混合架构设计实现180ms超低延迟与800MB内存控制&#xff0c;为智能手表、智能家居等终端设备提…

作者头像 李华
网站建设 2026/5/1 6:25:29

Lottie-Web性能优化实战:告别内存泄漏的完整策略

Lottie-Web性能优化实战&#xff1a;告别内存泄漏的完整策略 【免费下载链接】lottie-web Render After Effects animations natively on Web, Android and iOS, and React Native. http://airbnb.io/lottie/ 项目地址: https://gitcode.com/gh_mirrors/lo/lottie-web 你…

作者头像 李华
网站建设 2026/4/30 9:16:02

HoRain云--Java String类核心方法全解析

&#x1f3ac; HoRain 云小助手&#xff1a;个人主页 ⛺️生活的理想&#xff0c;就是为了理想的生活! ⛳️ 推荐 前些天发现了一个超棒的服务器购买网站&#xff0c;性价比超高&#xff0c;大内存超划算&#xff01;忍不住分享一下给大家。点击跳转到网站。 目录 ⛳️ 推荐 …

作者头像 李华