对象存储-MinIo

简介:

构建高性能的云原生数据、机器学习,大数据分析,海量存储的基础架构、MinIO支持各种应用程序数据工作负载。

特点:

  • 高性能
  • 可扩展性
  • 云的原生支持
  • 简单
  • 开放全部源代码 + 企业级支持
  • 与Amazon S3 兼容

一、搭建

支持Docker镜像部署

1、从hub.docker.com拉取最新镜像

命令:docker pull minio/minio (此命令就等同于 : docker pull minio/minio:latest)

2、创建目录

一个用来存放配置,一个用来存储上传文件的目录

启动前需要先创建Minio外部挂载的配置文件( /home/minio/config),和存储上传文件的目录( /home/minio/data)

mkdir -p /home/minio/configmkdir -p /home/minio/data

3、创建Minio容器并运行

多行命令

docker run -p 9000:9000 -p 9090:9090–net=host–name minio-d –restart=always-e “MINIO_ACCESS_KEY=minioadmin”-e “MINIO_SECRET_KEY=minioadmin”-v /home/minio/data:/data-v /home/minio/config:/root/.miniominio/minio server/data –console-address “:9090” -address “:9000”

单行命令

docker run -p 9000:9000 -p 9090:9090–net=host–name minio-d –restart=always-e “MINIO_ACCESS_KEY=minioadmin”-e “MINIO_SECRET_KEY=minioadmin”-v /home/minio/data:/data-v /home/minio/config:/root/.miniominio/minio server/data –console-address “:9090” -address “:9000”

9090:客户端端口

9000:api端口(项目中所用)

MINIO_ACCESS_KEY :账号

MINIO_SECRET_KEY :密码(账号长度必须大于等于5,密码长度必须大于等于8位)

4、客户端访问

地址:http://ip:9090

二、整合项目(SpringBoot项目)

1、application.yml

2、minio文件上传工具类

public class MinioUtil {private static String minioUrl;private static String minioName;private static String minioPass;private static String bucketName;public static void setMinioUrl(String minioUrl) {MinioUtil.minioUrl = minioUrl;}public static void setMinioName(String minioName) {MinioUtil.minioName = minioName;}public static void setMinioPass(String minioPass) {MinioUtil.minioPass = minioPass;}public static void setBucketName(String bucketName) {MinioUtil.bucketName = bucketName;}public static String getMinioUrl() {return minioUrl;}public static String getBucketName() {return bucketName;}private static MinioClient minioClient = null;/** * 上传文件 * @param file * @return */public static String upload(MultipartFile file, String bizPath, String customBucket) {String file_url = “”;//update-begin-author:wangshuai date:20201012 for: 过滤上传文件夹名特殊字符,防止攻击bizPath=StrAttackFilter.filter(bizPath);//update-end-author:wangshuai date:20201012 for: 过滤上传文件夹名特殊字符,防止攻击String newBucket = bucketName;if(oConvertUtils.isNotEmpty(customBucket)){newBucket = customBucket;}try {initMinio(minioUrl, minioName,minioPass);// 检查存储桶是否已经存在if(minioClient.bucketExists(BucketExistsArgs.builder().bucket(newBucket).build())) {log.info(“Bucket already exists.”);} else {// 创建一个名为ota的存储桶minioClient.makeBucket(MakeBucketArgs.builder().bucket(newBucket).build());log.info(“create a new bucket.”);}InputStream stream = file.getInputStream();// 获取文件名String orgName = file.getOriginalFilename();if(“”.equals(orgName)){orgName=file.getName();}orgName = CommonUtils.getFileName(orgName);String objectName = bizPath+”/”+orgName.substring(0, orgName.lastIndexOf(“.”)) + “_” + System.currentTimeMillis() + orgName.substring(orgName.lastIndexOf(“.”));// 使用putObject上传一个本地文件到存储桶中。if(objectName.startsWith(“/”)){objectName = objectName.substring(1);}PutObjectArgs objectArgs = PutObjectArgs.builder().object(objectName).bucket(newBucket).contentType(“application/octet-stream”).stream(stream,stream.available(),-1).build();minioClient.putObject(objectArgs);stream.close();file_url = minioUrl+newBucket+”/”+objectName;}catch (Exception e){log.error(e.getMessage(), e);}return file_url;}/** * 文件上传 * @param file * @param bizPath * @return */public static String upload(MultipartFile file, String bizPath) {returnupload(file,bizPath,null);}/** * 获取文件流 * @param bucketName * @param objectName * @return */public static InputStream getMinioFile(String bucketName,String objectName){InputStream inputStream = null;try {initMinio(minioUrl, minioName, minioPass);GetObjectArgs objectArgs = GetObjectArgs.builder().object(objectName).bucket(bucketName).build();inputStream = minioClient.getObject(objectArgs);} catch (Exception e) {log.info(“文件获取失败” + e.getMessage());}return inputStream;}/** * 删除文件 * @param bucketName * @param objectName * @throws Exception */public static void removeObject(String bucketName, String objectName) {try {initMinio(minioUrl, minioName,minioPass);RemoveObjectArgs objectArgs = RemoveObjectArgs.builder().object(objectName).bucket(bucketName).build();minioClient.removeObject(objectArgs);}catch (Exception e){log.info(“文件删除失败” + e.getMessage());}}/** * 获取文件外链 * @param bucketName * @param objectName * @param expires * @return */public static String getObjectURL(String bucketName, String objectName, Integer expires) {initMinio(minioUrl, minioName,minioPass);try{GetPresignedObjectUrlArgs objectArgs = GetPresignedObjectUrlArgs.builder().object(objectName).bucket(bucketName).expiry(expires).build();String url = minioClient.getPresignedObjectUrl(objectArgs);return URLDecoder.decode(url,”UTF-8″);}catch (Exception e){log.info(“文件路径获取失败” + e.getMessage());}return null;}/** * 初始化客户端 * @param minioUrl * @param minioName * @param minioPass * @return */private static MinioClient initMinio(String minioUrl, String minioName,String minioPass) {if (minioClient == null) {try {minioClient = MinioClient.builder().endpoint(minioUrl).credentials(minioName, minioPass).build();} catch (Exception e) {e.printStackTrace();}}return minioClient;}/** * 上传文件到minio * @param stream * @param relativePath * @return */public static String upload(InputStream stream,String relativePath) throws Exception {initMinio(minioUrl, minioName,minioPass);if(minioClient.bucketExists(BucketExistsArgs.builder().bucket(bucketName).build())) {log.info(“Bucket already exists.”);} else {// 创建一个名为ota的存储桶minioClient.makeBucket(MakeBucketArgs.builder().bucket(bucketName).build());log.info(“create a new bucket.”);}PutObjectArgs objectArgs = PutObjectArgs.builder().object(relativePath).bucket(bucketName).contentType(“application/octet-stream”).stream(stream,stream.available(),-1).build();minioClient.putObject(objectArgs);stream.close();return minioUrl+bucketName+”/”+relativePath;}}

3、controller

@PostMapping(value = “/uploadMinio”)public Result uploadMinio(HttpServletRequest request) {Result result = new Result();String bizPath = request.getParameter(“biz”);if(oConvertUtils.isEmpty(bizPath)){bizPath = “”;}MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;MultipartFile file = multipartRequest.getFile(“file”);// 获取上传文件对象String orgName = file.getOriginalFilename();// 获取文件名orgName = CommonUtils.getFileName(orgName);String file_url =MinioUtil.upload(file,bizPath);if(oConvertUtils.isEmpty(file_url)){return Result.error(“上传失败,请检查配置信息是否正确!”);}//保存文件信息OSSFile minioFile = new OSSFile();minioFile.setFileName(orgName);minioFile.setUrl(file_url);ossFileService.save(minioFile);result.setMessage(file_url);result.setSuccess(true);return result;}

4、前端组件

MINIO文件上传

好啦, 关于{对象存储-MinIo}分享就到这啦, 如果你是前端工程师同学,欢迎试用体验【webfunny监控系统】。

webfunny前端监控


Webfunny前端应用专注于微信小程序、H5前端、PC前端线上应用实时监控,实时监控前端网页、前端数据分析、错误统计分析监控和BUG预警,第一时间报警,快速修复BUG!支持私有化部署,容器化部署。

郑重声明:本文内容及图片均整理自互联网,不代表本站立场,版权归原作者所有,如有侵权请联系管理员(admin#wlmqw.com)删除。
(0)
用户投稿
上一篇 2022年9月19日
下一篇 2022年9月19日

相关推荐

  • 心理健康 – 八个步骤帮助改善孩子的行为

    如果你的孩子年龄在2-10岁之间,教养过程中有很多让你头疼的行为,例如不合作、不遵守规则、爱发脾气、总是与小朋友起冲突等等,那么你可以通过以下八个步骤来帮助改善孩子的行为。 第一步…

    2022年8月18日
  • 华为团队《python开发实战》高清PDF版开放下载

    华为,华为笔记本,华为系统,华为鸿蒙系统 今天推荐一套华为团队内部都在用的《python开发实战》,进入大厂不再是梦! 资料目录: 获取方式:

    2022年7月11日
  • 钉钉怎么设置文件下载路径

    钉钉怎么设置文件下载路径?今天就教大家如何操作使用方法步骤。 钉钉怎么设置文件下载路径 1、打开钉钉,点击左上角的头像; 2、在头像下方出现列表,选择”系统设置”; 3、往下滑动页…

    2022年5月1日
  • 微信20分钟竟然撤回了(微信超时怎样强制撤回)

    最近微信又有新的变化了,意想不到的是 “ 微信撤销时间延长 ” ,是不觉得很熟悉呢? 众所周知,在微信聊天中,微信发出的有效消息后,撤销的功能仅限于2之内,但其实,消息撤销的类别不…

    2022年10月26日
  • /bin/ld: 找不到 -lcrypto

    目录 场景 出现问题 问题分析 解决方法 场景 当我们对某个源码包进行编译安装,再执行 configure 有时候会因为找不到库文件,报错如下: [root@localhost ~…

    2022年6月14日
  • Python 模块paramiko

    paramiko 模块 paramiko 是一个用 Python 语言编写的、遵循 SSH2 协议、支持以加密和认证方式进行连接远程服务器的模块。改模块可以对远程服务器进行一些命令…

    2022年7月4日
  • Java子线程中的异常处理(通用)

    在普通的单线程程序中,捕获异常只需要通过try … catch … finally …代码块就可以了。那么,在并发情况下,比如在父线程中启动了子…

    2022年6月21日
  • 解决maven依赖冲突,这篇就够了

    一、前言 什么是依赖冲突 依赖冲突是指项目依赖的某一个jar包,有多个不同的版本,因而造成了包版本冲突。 依赖冲突的原因 我们在maven项目的pom中 一般会引用许许多多的dep…

    2022年6月20日
  • Here we go!罗马诺:巴萨签拉菲尼亚达协议,总费用6700万欧

    直播吧7月13日讯 记者罗马诺消息,巴萨签拉菲尼亚达成全面协议,双方将签约至2027年,固定转会费5800万欧,总花费6700万欧。 据加泰媒体RAC1报道,拉菲尼亚将在当地时间周…

    2022年7月18日
  • openssl 如何生成自签证书

    1. 创建 openssl 配置文件 openss.cnf 创建目录 mkdir certscd certs 创建 openssl 配置文件 openss.cnf [req_dis…

    2022年6月20日

联系我们

联系邮箱:admin#wlmqw.com
工作时间:周一至周五,10:30-18:30,节假日休息