MinIO 分布式文件系统 快速入门 这篇就够了

2024-06-09 13:36

本文主要是介绍MinIO 分布式文件系统 快速入门 这篇就够了,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.MinIO简介

        MinIO 是一个开源的对象存储服务,它提供了一个可扩展的分布式文件系统,用于存储和检索任意类型的数据。MinIO 旨在为云原生应用程序提供快速、可靠和成本效益高的存储服务,并支持多种数据格式和协议,如Amazon S3 API。

2. 在docker上部署minio

关于docker上的部署这篇讲解很详细,大家可以参考

http://t.csdnimg.cn/FWT1Yicon-default.png?t=N7T8http://t.csdnimg.cn/FWT1Y

3. minio的基本使用

3.1 创建bucket

 

3.2 上传文件(打开bucket的右边)

4. 使用Java代码实现minIO

4.1 引入依赖

        <dependency><groupId>io.minio</groupId><artifactId>minio</artifactId><version>8.4.3</version></dependency><dependency><groupId>com.squareup.okhttp3</groupId><artifactId>okhttp</artifactId><version>4.8.1</version></dependency>

4.2 上传文件、删除文件、下载文件的代码

@SpringBootTest
class MinioDemoApplicationTests {// 创建一个MinioClient实例,用于与MinIO服务器的交互MinioClient minioClient =MinioClient.builder().endpoint("http://192.168.92.136:9000") // MinIO服务器的地址.credentials("minioadmin","minioadmin") // MinIO服务的访问凭证.build();// 上传文件@Testvoid testUpload() throws Exception {// 创建上传文件的参数信息UploadObjectArgs uploadObjectArgs = UploadObjectArgs.builder().bucket("testbucket") // 指定上传到哪个桶.filename("C:\\Users\\haoge\\Pictures\\9780fe1eaa34499fa37f560e6f9a2818_1507729237.png") // 本地文件的路径.object("9780fe1eaa34499fa37f560e6f9a2818_1507729237.png") // 在MinIO中存储的文件名.build();// 使用MinioClient上传文件minioClient.uploadObject(uploadObjectArgs);}// 删除文件@Testvoid testDelete() throws Exception{// 创建删除文件的参数信息RemoveObjectArgs removeObjectArgs = RemoveObjectArgs.builder().bucket("testbucket") // 指定从哪个桶删除.object("9780fe1eaa34499fa37f560e6f9a2818_1507729237.png") // 要删除的文件名.build();// 使用MinioClient删除文件minioClient.removeObject(removeObjectArgs);}// 下载文件@Testvoid testGetFile() throws Exception{// 创建获取文件的参数信息GetObjectArgs getObjectArgs = GetObjectArgs.builder().bucket("testbucket") // 指定从哪个桶获取文件.object("9780fe1eaa34499fa37f560e6f9a2818_1507729237.png") // 要获取的文件名.build();// 使用MinioClient获取文件的输入流FilterInputStream inputStream = minioClient.getObject(getObjectArgs);// 创建本地文件的输出流FileOutputStream outputStream = new FileOutputStream(new File("D:\\1.png"));// 使用IOUtils的copy方法将输入流中的数据复制到输出流中,即写入到本地文件IOUtils.copy(inputStream, outputStream);}
}

这篇关于MinIO 分布式文件系统 快速入门 这篇就够了的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1045321

相关文章

Linux(Centos7)安装Mysql/Redis/MinIO方式

《Linux(Centos7)安装Mysql/Redis/MinIO方式》文章总结:介绍了如何安装MySQL和Redis,以及如何配置它们为开机自启,还详细讲解了如何安装MinIO,包括配置Syste... 目录安装mysql安装Redis安装MinIO总结安装Mysql安装Redis搜索Red

shell脚本快速检查192.168.1网段ip是否在用的方法

《shell脚本快速检查192.168.1网段ip是否在用的方法》该Shell脚本通过并发ping命令检查192.168.1网段中哪些IP地址正在使用,脚本定义了网络段、超时时间和并行扫描数量,并使用... 目录脚本:检查 192.168.1 网段 IP 是否在用脚本说明使用方法示例输出优化建议总结检查 1

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、

Rust中的Option枚举快速入门教程

《Rust中的Option枚举快速入门教程》Rust中的Option枚举用于表示可能不存在的值,提供了多种方法来处理这些值,避免了空指针异常,文章介绍了Option的定义、常见方法、使用场景以及注意事... 目录引言Option介绍Option的常见方法Option使用场景场景一:函数返回可能不存在的值场景

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联