Docker:使用MinIO搭建对象存储平台

请关注微信公众号:拾荒的小海螺
博客地址:http://lsk-ww.cn/

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作为一款开源的对象存储系统,具有高性能、高可用性和易部署等特点,为用户提供了一种简单、高效的对象存储解决方案。

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

拾荒的小海螺

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值