分布式文件存储系统minio了解下

什么是minio

minio 是一个基于 Apache License v2.0 开源协议的对象存储服务。非常适合于存储大容量非结构化的数据,例如图片、视频、日志文件、备份数据和容器/虚拟机镜像等,而一个对象文件可以是任意大小。 是一种海量、安全、低成本、高可靠的云存储服务,适合存放任意类型的文件。容量和处理能力弹性扩展,多种存储类型供选择,全面优化存储成本。

如果不考虑文件存储上云,minio 是一个非常不错的选择,并且支持分布式部署。

如何使用 minio 进行文件上传

// 引入mioio的依赖包<!-- minio --><dependency><groupId>io.minio</groupId><artifactId>minio</artifactId><version>7.1.4</version></dependency>
// controller层
@PostMapping(value = "/uploadFile", headers = "content-type=multipart/form-data")
public Response<List<FileReturn>> uploadFiles(List<MultipartFile> fileList) {return fileService.uploadFileList(fileList);}
// service层 --- 伪代码
public List<FileReturn> uploadFileList(List<MultipartFile> fileList) {// 参数校验if (CollectionUtils.isEmpty(fileList)) {// throw new Exception}List<FileVO> fileVOList = new ArrayList<>();List<FileReturn> fileReturnList = new ArrayList<>();// String userId = xxxx;for (MultipartFile file : fileList) {// 校验文件 todo// 开始上传try {// 将文件存入minioMap<String, String> fileMap = minioClient.putObject(file);// 创建文件对象,设置属性FileVO fileVO = new FileVO().init(userId).setFileType(suffix).setFileOldName(Base64.decodeStr(fileMap.get(FileModel.OLD_NAME), "UTF-8")).setFileName(fileMap.get(FileModel.NAME)).setFilePath(fileMap.get(FileModel.NAME)).setFileNetPath(fileMap.get(FileModel.URL)).setFileSize(new BigDecimal(fileMap.get(FileModel.SIZE))).setFileUploadUser(userId).setFileUploadTime(LocalDateTime.now());fileVO.setId(IdWorker.getId());fileVOList.add(fileVO);// 返回文件id,文件url,文件名FileReturn fileReturn = new FileReturn().setFileId(fileVO.getId()).setFileNetPath(fileVO.getFileNetPath()).setFileAbsolutePath(this.preview(fileVO.getFileNetPath())).setFileOldName(fileVO.getFileOldName());fileReturnList.add(fileReturn);} catch (Exception e) {// 删除minio中已经保存的文件if (fileReturnList.size() > 0) {fileReturnList.forEach(vo -> minioClient.removeObject(vo.getFileNetPath()));}log.info("上传文件异常", e);// throw new Exception}}// 保存附件信息到数据库 持久化mapper.saveList(fileVOList);return fileReturnList;}

文件下载

// service层
// 文件下载前端传入文件id --- 伪代码public void downloadFile(String fileId, HttpServletResponse response) {FileVO contractFile = mapper.selectById(fileId);if (!Objects.isNull(contractFile)) {try {response.setHeader("Content-Disposition", "attachment;filename=" + contractFile.getFileName());minioClient.getObject(contractFile.getFilePath(), response.getOutputStream());// 持久化:记录下载次数,根据业务来处理// ...} catch (IOException e) {throw new RuntimeException(e);}}}

文件删除

// service层 --- 伪代码
public String removeFile(String fileId, HttpServletResponse response) {FileVO contractFile = mapper.selectById(fileId);if (!Objects.isNull(contractFile)) {try {response.setHeader("Content-Disposition", "attachment;filename=" + contractFile.getFileName());// 删除minio文件minioClient.removeFile(contractFile.getFilePath());// 删除数据库文件 持久化操作// ...} catch (IOException e) {// return "删除失败";}}return "删除成功";}

文件预览

// service层 --- 伪代码
// 返回文件的url全路径即可public String preview(String filePath) {String url = "";if (StringUtils.isNotEmpty(filePath)) {int index = filePath.indexOf('/');String objectName = filePath.substring(index + 1);url = minioClient.getObjectUrl(objectName, 24 * 3600, Method.GET);}return url;}public String getObjectUrl(String objectName, Integer expires, Method method) {try {if (expires >= 1 && expires <= 604800) {if (method == null) {method = Method.GET;}return minioClient.getPresignedObjectUrl((GetPresignedObjectUrlArgs)((io.minio.GetPresignedObjectUrlArgs.Builder)((io.minio.GetPresignedObjectUrlArgs.Builder)GetPresignedObjectUrlArgs.builder().method(method).bucket(minioConfig.getBucket())).object(objectName)).expiry(expires, TimeUnit.SECONDS).build());} else {throw new InvalidExpiresRangeException(expires, "expires must be in range of 1 to 604800");}} catch (Throwable var6) {throw new BusinessException(FILE_LOAD_EXCEPTION.getCode(), FILE_LOAD_EXCEPTION.getMessage(), var6.getMessage());}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/225366.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习笔记 - 用于自动化检测服饰的YOLOs-Fashionpedia模型

一、安装环境 使用预训练模型和 PyTorch Lightning 来自动化产品标记过程,将大幅度提高耗时的任务的效率。 # 安装软件包 pip install torch== 2.0 .0 pip install pytorch-lightning== 2.0 .1 pip install datasets== 2.11 .0 pip install Transformers== 4.30

Map.entry用法详解

Map.entry用法详解 大家好&#xff0c;我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;在Java编程的旅途中&#xff0c;Map.Entry是一位不可或缺的伙伴&#xff0c;为我们提供了在Map中…

Java: Random

/*** encoding: utf-8* 版权所有 2023 涂聚文有限公司* 许可信息查看&#xff1a;* 描述&#xff1a; //https://commons.apache.org/proper/commons-lang/javadocs/api-2.6/org/apache/commons/lang/RandomStringUtils.html* //https://commons.apache.org/pro…

#HarmonyOS:UIAbility组件生命周期--UIAbility组件启动模式

UI界面的应用组件&#xff0c;主要用于和用户交互。 UIAbility组件生命周期 UIAbility的生命周期包括Create、 onWindowStageCreate、Foreground、Background、onWindowStageDestroy Destroy四个状态 UIAbility组件启动模式 singleton&#xff08;单实例模式&#xff09;…

详解RTC:以华人文化打造链上生态

文化是人类在发展的历史长河中淘洗出来的智慧结晶&#xff0c;随着人类社会的进步和变迁&#xff0c;经历了从口口相传到互联网等不同历史时代的传承和创新。在数字技术飞速发展的当今&#xff0c;区块链技术为文化的创新与传承提供了全新的空间和方式&#xff0c;使其得以在新…

ACL与NAT

目录 一、ACL &#xff08;一&#xff09;ACL基本理论 &#xff08;二&#xff09;ACL的类型 1.基本ACL 2.高级ACL 3.二层ACL &#xff08;三&#xff09;基本原理 &#xff08;四&#xff09;项目实验 通配符掩码 二、NAT &#xff08;一&#xff09;基本理论 &am…

ansible的基本使用

本章主要介绍在RHEL8中如何安装ansible 及 ansible 的基本使用。 ansible是如何工作的在 RHEL8中安装ansible编写ansible.cfg和清单文件ansible 的基本用法 如果管理的服务器很多&#xff0c;如几十台甚至几百台&#xff0c;那么就需要一个自动化管理工具了&#xff0c; ansi…

【人生感悟】涅槃重生

哪里更容易挣钱&#xff0c;哪里更有发展的空间 心很定 如何做个内心强大的人 首先、要为自己而活。把你全部注意力和能量全部收回到你这个人本身身上&#xff0c;不要去在意别人对你的评价&#xff0c;不要去猜测别人的想法&#xff0c;不要急切的向外界证明你自己。 第二…

Elasticsearch Spring Data集成-05

Elasticsearch集成 Spring Data是一个用于简化数据库、非关系型数据库、索引库访问&#xff0c;并支持云服务的开源框架。其主要目标是使得对数据的访问变得方便快捷&#xff0c;并支持 map-reduce框架和云计算数据服务。Spring Data可以极大的简化JPA(Elasticsearch…)的写法…

Linux wc命令教程:如何有效地统计文件的行数、字数和字符数(附案例详解和注意事项)

Linux wc命令介绍 wc命令在Linux中是一个非常实用的工具&#xff0c;全称为word count&#xff0c;主要用于统计文本文件中行的数量、单词的数量以及字符的数量。 Linux wc命令适用的Linux版本 wc命令在大多数Linux发行版中都是默认安装的&#xff0c;包括但不限于Ubuntu, D…

23. 常用shell之 df - 显示磁盘空间使用情况 的用法和衍生用法

df&#xff08;disk free&#xff09;是一个在 Unix 和类 Unix 系统&#xff08;如 Linux 和 macOS&#xff09;中用于显示磁盘空间使用情况的命令。这个命令对于系统管理员和用户来说非常重要&#xff0c;因为它可以帮助监控和管理磁盘空间的使用情况。 基本用法 df 命令的基…

跟随鼠标动态显示线上点的值(基于Qt的开源绘图控件QCustomPlot进行二次开发)

本文为转载 原文链接&#xff1a; 采用Qt快速绘制多条曲线&#xff08;折线&#xff09;&#xff0c;跟随鼠标动态显示线上点的值&#xff08;基于Qt的开源绘图控件QCustomPlot进行二次开发&#xff09; 内容如下 QCustomPlot是一个开源的基于Qt的第三方绘图库&#xff0c;能…

打工人副业变现秘籍,某多/某手变现底层引擎-Stable Diffusion 黑白老照片上色修复

在这个时代,我们习惯于拥有高清、色彩丰富的照片,然而,那些古老的黑白色老照片由于年代的久远,往往会出现模糊、破损等现象。 那么今天要给大家介绍的是,用 Stable Diffusion 来修复老照片。 前段时间 ControlNet 的除了上线了“IP-Adapter”模型以外还增加另一个…

【深度学习】TensorFlow深度模型构建:训练一元线性回归模型

文章目录 1. 生成拟合数据集2. 构建线性回归模型数据流图3. 在Session中运行已构建的数据流图4. 输出拟合的线性回归模型5. TensorBoard神经网络数据流图可视化6. 完整代码 本文讲解&#xff1a; 以一元线性回归模型为例&#xff0c; 介绍如何使用TensorFlow 搭建模型 并通过会…

【Android12】Android Framework系列--AMS启动Activity分析

AMS启动Activity分析 通过ActivityManagerService(AMS)提供的方法&#xff0c;可以启动指定的Activity。比如Launcher中点击应用图标后&#xff0c;调用AMS的startActivity函数启动应用。 AMS提供的服务通过IActivityManager.aidl文件定义。 // frameworks/base/core/java/an…

KafKa基本原理

分布式&#xff0c;分区&#xff0c;多副本&#xff0c;zk协调的分布式消息系统 使用 日志收集 消息系统 用户活动跟踪 运营指标 概念 Broker topic producer consumer consumergroup partition 通信基于tcp协议 很多集群信息记录在zk里保证自己的无状态&#xff0c;方便…

使用Python将HTML快速转换成PDF

大家好&#xff0c;在Web开发和报告任务中&#xff0c;将HTML内容转换为PDF是一种常见需求。Python作为一个庞大的生态系统&#xff0c;提供了各种库来完成这个任务。本文将指导完成使用Python将HTML转换为PDF的过程&#xff0c;包括一个示例实现和一个单元测试。我们将使用pdf…

Python将已标注的两张图片进行上下拼接并修改、合并其对应的Labelme标注文件(v2.0)

Python将已标注的两张图片进行上下拼接并修改、合并其对应的Labelme标注文件&#xff08;v2.0&#xff09; 前言前提条件相关介绍实验环境上下拼接图片并修改、合并其对应的Labelme标注文件代码实现输出结果 前言 此版代码&#xff0c;相较于Python将已标注的两张图片进行上下拼…