侧边栏壁纸
博主头像
拾荒的小海螺博主等级

只有想不到的,没有做不到的

  • 累计撰写 139 篇文章
  • 累计创建 15 个标签
  • 累计收到 0 条评论

目 录CONTENT

文章目录
OPS

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

拾荒的小海螺
2024-04-26 / 0 评论 / 0 点赞 / 11 阅读 / 5622 字

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:

193114D9-38F5-4b77-BC3C-06E3AC6736F4.png

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

0

评论区