高性能对象存储minio

Posted 墨家巨子@俏如来

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高性能对象存储minio相关的知识,希望对你有一定的参考价值。

MinIO介绍

MinIO 是在 Apache License v2.0 下发布的高性能对象存储。 它是与 Amazon S3 云存储服务兼容的 API。MinIO 是一个高性能的对象存储原生支持 Kubernetes 部署的解决方案。

Minio 是一个非常轻量的服务,它可以存储⼤容量的⾮结构化数据,例如图⽚、视频、⽇志⽂件、备份数据和容器/虚拟机镜像等。对于⼤多数的企业来说,这可以说是最为理想的存储媒介了。而一个对象文件可以是任意大小,从几 kb 到最大 5T 不等。

MinIO具备如下特性

  • 部署简单,支持各种平台
  • 高性能海量存储,支持单个对象最大5TB
  • 兼容 Amazon S3接口
  • SDK 支持:有类似 Java、Python 或 Go 等语言的 sdk 支持
  • 数据保护:即使损坏一般的磁盘依然可用数据恢复
  • 高性能:可用达到55G每秒读,35G每秒写的速度

使用Docker 安装 MinIO

第一步:启动一个miniio容器 , 官方文档

docker run --name minio -p 9090:9000 -p 9999:9999 -d \\
--restart=always -e \\
"MINIO_ROOT_USER=minioadmin" \\
-e "MINIO_ROOT_PASSWORD=minioadmin123?" \\
-v /home/minio/data:/data \\
-v /home/minio/config:/root/.minio minio/minio server /data --console-address '0.0.0.0:9999'

第二步:访问minio管理界面 ,端口9090

点击 create a Bucket 创建一个bucket(桶), 这里的Bucket 我们可以理解为文件存储的目录

输入 bucket name ,点击create bucket 。可以通过 upload 上传文件到bucket中。

Java 上传文件到minio

第一步:导入minio的依赖 ,参考文档 Minio官方文档

<dependency>
    <groupId>io.minio</groupId>
    <artifactId>minio</artifactId>
    <version>7.1.0</version>
</dependency>

第二步:编写一个测试类

public static void main(String[] args) throws Exception 
        try 
        
            // 构建一个Minio客户端
            MinioClient minioClient = MinioClient.builder()
            		//创建容器时指定的账号
                    .credentials("minioadmin", "minioadmin123?")
                    //上传地址
                    .endpoint("http://minio服务器IP:9090").build();

            File file = new File("d:/图片.jpg");

            PutObjectArgs putObjectArgs = PutObjectArgs.builder()
                    .object("图片.jpg")	//文件名
                    .contentType("image/jpeg")	//文件类型
                    .bucket("bucket-test")  //存储目录名
                    .stream(new FileInputStream(file), file.length(), -1).build(); //文件流,以及大小,-1代表不分片

			//执行上传
            ObjectWriteResponse objectWriteResponse = minioClient.putObject(putObjectArgs);
            System.out.println("上传结果 "+objectWriteResponse);
			//上传之后的文件地址是:
            String filePath = "http://115.159.88.63:9090/bucket-test/图片.jpg";

         catch(MinioException e) 
            System.out.println("Error occurred: " + e);
        
    

执行测试代码之后,观看minio管理界面,多了一个图片

配置权限

我这里上传了一个图片,上传之后,图片的访问地址是:  http://minio服务器ip:9090/存储目录/文件名,但是你访问的时候会出现这样的错误 ,那是因为匿名(游客没登录)用户没有访问权限

如果我们需要我们上传的文件可以被匿名用户访问,那么需要添加访问权限:找到文件存储目录,点击manager


然后找到access Rules添加访问规则如下:

然后再次访问,就可以看到上传的图片了


文章就到这里把,喜欢的话建议收藏,顺便给个好评哦,一键三连就更好啦!!!

以上是关于高性能对象存储minio的主要内容,如果未能解决你的问题,请参考以下文章

MinIO 快速入门之一 —— MinIO 简介

高性能云原生数据对象存储MinIO实战-上

对象存储MinIO的简介与部署

MinIO的搭建

如何使用Minio进行对象存储和数据管理

minio对象存储