请关注微信公众号:拾荒的小海螺
1、简述
MinIO是一个基于对象存储技术的开源项目,它可以帮助用户快速搭建起私有的、高性能的对象存储平台。MinIO兼容Amazon S3 API,使得用户可以使用标准的S3工具和SDK来访问和管理MinIO存储的数据。此外,MinIO还提供了分布式部署、自动数据完整性检查、强大的安全性功能等特性,使得其成为了企业级对象存储方案的首选。
MinIO 之所以广受欢迎,是因为其具有以下特点:
-
高性能。
MinIO 是全球领先的对象存储服务先锋,目前在全世界有数百万的用户。在标准硬件上,读/写速度高达每秒几百 GB。 -
可扩展性。
MinIO 借鉴了 Web 缩放器,为对象存储带来了简单的扩缩模型。在部署 MinIO 时,扩展从单个群集开始。 -
云原生支持。
MinIO 是在过去几年内从 0 开始打造的一款存储方案,符合一切云原生计算的架构和构建流程,并且包含最新的云计算技术和理念。 -
纯开源。
MinIO 基于 Apache V2 license 100% 开放源代码。这就意味着 MinIO 的客户能够自动、无限制、自由免费地使用和集成 MinIO、自由创新和创造、自由修改和完善、自由再次发行新版本和组合软件。 -
兼容 S3 存储。
AWS 的 S3 API(接口协议)是在全球范围内达到共识的对象存储协议,是全世界内大家都认可的标准。 -
极简。
极简主义是 MinIO 的指导性设计原则。简单性减少了出错的机会,提高了正常运行时间,提供了可靠性,同时简单性又是性能的基础。 -
支持多云。
可以创建数以百万计的实例部署在私有云、公有云和边缘计算环境。
2、安装
创建用于存放Minio外部挂载的配置文件目录和存储上传文件的目录:
mkdir -p /shop/minio/data
mkdir -p /shop/minio/config
通过docker指令拉取Minio线上最新的版本:
docker pull minio/minio
通过docker run 运行当前Minio镜像:
docker run \
--name minio \
-p 9000:9000 \
-p 9090:9090 \
-d --restart=always \
-e "MINIO_ACCESS_KEY=minioadmin" \
-e "MINIO_SECRET_KEY=minioadmin" \
-v /shop/minio/data:/data \
-v /shop/config:/root/.minio \
minio/minio server /data --console-address ":9090"
运行成功后,打开浏览器,访问Linux 的9090端口,即可看到 MinIO:
备注:API访问要通过9000端口来实现:
API: http://192.168.0.4:9000 http://127.0.0.1:9000
WebUI: http://192.168.0.4:9090 http://127.0.0.1:9090
3、准备工作
首先,确保已经在本地或远程服务器上部署了MinIO服务,并获取到MinIO的访问密钥(Access Key)和密钥(Secret Key)。
其次,我们需要在Java项目中引入MinIO的Java SDK依赖。可以通过Maven或Gradle进行管理,在 pom.xml 或 build.gradle 中添加以下依赖:
<dependency>
<groupId>io.minio</groupId>
<artifactId>minio</artifactId>
<version>7.1.0</version>
</dependency>
3.1 实现上传文件功能
import io.minio.MinioClient;
import io.minio.errors.MinioException;
import io.minio.messages.Bucket;
import java.io.IOException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
public class MinioUploader {
public static void main(String[] args) {
try {
// 初始化MinioClient对象
MinioClient minioClient = MinioClient.builder()
.endpoint("http://minio.example.com") // MinIO服务器地址
.credentials("YOUR_ACCESS_KEY", "YOUR_SECRET_KEY") // 访问密钥和密钥
.build();
// 检查存储桶是否存在,不存在则创建
boolean isExist = minioClient.bucketExists("my-bucket");
if (!isExist) {
minioClient.makeBucket("my-bucket");
}
// 上传文件
minioClient.uploadObject("my-bucket", "example-file.txt", "/path/to/local/file");
System.out.println("文件上传成功!");
} catch (MinioException | IOException | InvalidKeyException | NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
}
3.2 实现下载文件功能
import io.minio.MinioClient;
import io.minio.errors.MinioException;
import java.io.IOException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
public class MinioDownloader {
public static void main(String[] args) {
try {
// 初始化MinioClient对象
MinioClient minioClient = MinioClient.builder()
.endpoint("http://minio.example.com") // MinIO服务器地址
.credentials("YOUR_ACCESS_KEY", "YOUR_SECRET_KEY") // 访问密钥和密钥
.build();
// 下载文件
minioClient.downloadObject("my-bucket", "example-file.txt", "/path/to/local/destination");
System.out.println("文件下载成功!");
} catch (MinioException | IOException | InvalidKeyException | NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
}
在以上示例中,我们通过Java SDK与MinIO建立连接,实现了文件的上传和下载功能。在实际项目中,可以根据需要对上传、下载的文件进行更详细的处理和管理,例如文件的权限设置、元数据管理等。
4、总结
通过本文的介绍,你已经了解了如何使用Docker来快速部署和运行MinIO服务。MinIO作为一款开源的对象存储系统,具有高性能、高可用性和易部署等特点,为用户提供了一种简单、高效的对象存储解决方案。