Minio文件上传实战

前言:

本文涉及知识范围包括腾讯云服务器、docker、Minio、springBoot集成Minio 相关知识, 相信读者对这些知识已是能信手拈来, 在这里,你可以看到我以下实战:

  • docker集成Minio,并启动Minio服务
  • springBoot集成Minio,上传图片、视频、日志文件等数据到Minio服务器上

相信屏幕前的你,已经掌握了在云服务器使用docker的常规使用,在这里,直接从docker下载Minio开始

docker集成Minio

在腾讯云服务器控制台(OrcaTerm)输入如下命令(注:有权限校验的时候,暂时又不想去配置相关权限的,可以直接在命令前加sudo(MacOs系统)),下载Minio镜像:

shell 复制代码
docker pull bitnami/minio

下载成功Minio镜像后,为Minio创建数据卷目录:

shell 复制代码
mkdir -p /minio_01/data

docker启动一个Minio镜像:

shell 复制代码
docker run -it -d --name minio -p 9000:9000 -p 9001:9001 -v /minio/data:/data -e MINIO_ROOT_USER="minio_root" -e MINIO_ROOT_PASSWORD="minio_admin_12345" bitnami/minio:latest

参数注解:

  1. -it:以交互的模式启动容器
  2. -d:以守护进程方式启动容器
  3. -p:指定端口号,如果不想设定可以使用-P
  4. -v:是挂载数据卷的,作用就是,对数据进行备份,可以防止误删
  5. -e:是配置项,在这里配置静态key/value,是的,打开Minio服务的用户名和密码

运行启动命令后,可以看看Minio启动后的日志:

shell 复制代码
docker logs minio -f

效果如下:

到这里,就已经在docker集成并启动了Minio服务了。 想通过云服务器公网ip访问,需要在云服务器防火墙模板配置允许访问防火墙,创建模板minio:

配置完两个可访问端口号后,需要在设置实例防火墙操作项中,添加你的云服务器在实例中才可以在浏览器访问:ip+9001 或如绑定了域名,域名+9001访问Minio服务器

输入在dokcer启动Minio服务时日志中的RootUser和RootPass就可以登录进入Minio可视化系统了:

到这里,你可以在可视化系统里手动创建BucketName并上传、下载文件,但,本文的目的是,通过springBoot集成Minio链接Minio服务地址创建BucketName并实现前后端分离上传自媒体文件。

springBoot集成Minio

在这里直接上代码

java 复制代码
@ApiOperation(value = "文件上传")
@PostMapping(value = "/upload",headers = "content-type=multipart/form-data")
public CommonResult upload(@RequestPart("file") MultipartFile file){
   try{
       // 创建一个MinIO的java客户端,xxx.xx.xxx.xx是你的服务器ip或域名
       // ACCESS_KEY和SECRET_KEY在Minio可视化系统里生成
       // BUCKET_NAME:需要符合BucketName的命名规则,全是小写的就可以:supermall
       MinioClient minioClient = MinioClient.builder()
               .endpoint("http://xxx.xx.xxx.xx",9000,false)
               .credentials("ACCESS_KEY","SECRET_KEY")
               .build();
       boolean isExit = minioClient.bucketExists(BucketExistsArgs.builder().bucket("supermall").build());
       if(isExit){
           LOGGER.info("存储桶已经存在");
       }else {
           // 创建存储桶并设置只读权限
           minioClient.makeBucket(MakeBucketArgs.builder().bucket("supermall").build());
           BucketPolicyConfig bucketPolicyConfig = createBucketPolicyConfig("supermall");
           SetBucketPolicyArgs bucketPolicyArgs = SetBucketPolicyArgs.builder()
                   .bucket("supermall")
                   .config(JSONUtil.toJsonStr(bucketPolicyConfig))
                   .build();
           minioClient.setBucketPolicy(bucketPolicyArgs);
       }
       String filename = file.getOriginalFilename();
       SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
       // 设置存储对象名称
       String objectName = sdf.format(new Date())+"/"+filename;
       // 使用putObject上传一个文件到存储桶中
       PutObjectArgs putObjectArgs = PutObjectArgs.builder()
               .bucket("supermall")
               .object(objectName)
               .contentType(file.getContentType())
               .stream(file.getInputStream(),file.getSize(),ObjectWriteArgs.MIN_MULTIPART_SIZE)
               .build();
       minioClient.putObject(putObjectArgs);
       LOGGER.info("文件上传成功!");
       MinioUpload minioUpload = new MinioUpload();
       minioUpload.setName(filename);
       minioUpload.setUrl(ENDPOINT + "/" + "supermall" + "/" + objectName);
       return CommonResult.success(minioUpload);
   }catch (Exception e){
       e.printStackTrace();
       LOGGER.info("上传发生错误:{}!",e.getMessage());
   }
    return CommonResult.failed();
}

启动项目后访问接口(演示是使用swagger测试的):

同时在Minio服务器系统也能看到上传的文件:

结语

Minio文件上传实践到这里分享完了,这是一个完整的文件上传过程,希望读者有所收获,共勉!!!

相关推荐
测试界柠檬1 分钟前
面试真题 | web自动化关闭浏览器,quit()和close()的区别
前端·自动化测试·软件测试·功能测试·程序人生·面试·自动化
多多*2 分钟前
OJ在线评测系统 登录页面开发 前端后端联调实现全栈开发
linux·服务器·前端·ubuntu·docker·前端框架
2301_801074153 分钟前
TypeScript异常处理
前端·javascript·typescript
小阿飞_4 分钟前
报错合计-1
前端
hai405874 分钟前
Spring Boot中的响应与分层解耦架构
spring boot·后端·架构
caperxi6 分钟前
前端开发中的防抖与节流
前端·javascript·html
霸气小男6 分钟前
react + antDesign封装图片预览组件(支持多张图片)
前端·react.js
susu10830189116 分钟前
前端css样式覆盖
前端·css
学习路上的小刘8 分钟前
vue h5 蓝牙连接 webBluetooth API
前端·javascript·vue.js
&白帝&8 分钟前
vue3常用的组件间通信
前端·javascript·vue.js