亲宝软件园·资讯

展开

Springboot minio文件存储

、楽. 人气:0

在我们平时做项目的时候,文件存储是个很常见的需求。这时候我们就会用到对象存储服务,平时我们可能会选择OSS、AWS S3这类第三方服务。今天带大家搭建一款自己的对象存储服务,带可视化管理,用起来也挺简单。

MinIO 是一款基于Go语言的高性能对象存储服务,它采用了Apache License v2.0开源协议,非常适合于存储大容量非结构化的数据,例如图片、视频、日志文件、备份数据和容器/虚拟机镜像等。

1. 安装部署

1.1 Linux 简单部署

wget https://dl.min.io/server/minio/release/linux-amd64/minio

chmod +x minio 

MINIO_ROOT_USER=admin MINIO_ROOT_PASSWORD=123456 

##启动并指定端口
./minio server /mnt/data --console-address ":9001"

## 或者后台启动
nohup ./minio server /mnt/data  >  /opt/minio/minio.log 2>&1 &#

image-20220312150958112

然后访问对应地址即可:云服务器的话记得去安全组打开对应端口,账号密码如图所示:

image-20220312151047653

1.2 Docker 部署

#下载MinIO的Docker镜像 
docker pull minio/minio 
#--console-address指定MinIO Console的运行端口 (否则会随机端口运行) 暴露端口9001或者9000 
docker run -p 9090:9000 -p 9001:9001 --name minio \ -v /mydata/minio/data:/data \ -e MINIO_ROOT_USER=minioadmin \ -e MINIO_ROOT_PASSWORD=minioadmin \ -d minio/minio server /data --console-address ":9001"

2. Spring boot 整合

添加相关依赖

<!--        引入minio依赖-->
<dependency>
    <groupId>io.minio</groupId>
    <artifactId>minio</artifactId>
    <version>8.0.3</version>
</dependency>

添加相关配置信息

默认安装不指定Access key 和Secret key 的话都是minioadmin, Endpoint则为服务器API地址.

spring:
  # 配置文件上传大小限制
  servlet:
    multipart:
      max-file-size: 100MB
      max-request-size: 100MB

# minio 参数配置
minio:
  endpoint: http://127.0.01:9000
  accessKey: minioadmin
  secretKey: minioadmin

注入客户端

将客户端注入Spring容器中,使用的时候直接获取即可。

@Configuration
public class MinIoConfig {

    @Value("${minio.endpoint}")
    private String endpoint;
    @Value("${minio.accessKey}")
    private String accessKey;
    @Value("${minio.secretKey}")
    private String secretKey;

    /**
     * 注入minio 客户端
     *
     * @return
     */
    @Bean
    public MinioClient minioClient() {

        return MinioClient.builder()
                .endpoint(endpoint)
                .credentials(accessKey, secretKey)
                .build();
    }
}

编写相关业务代码

编写相关业务代码,上传图片后将相关的路径回传。

/**
 * 文件上传 (自定义文件名称)
 */
public MinIoUploadVo upload(String strDir, MultipartFile multipartFile) throws Exception {

    // bucket 不存在,创建
    if (!this.bucketExists(strDir)) {
        this.makeBucket(strDir);
    }
    InputStream inputStream = multipartFile.getInputStream();
    // 创建一个 headers
    Map<String, String> headers = new HashMap<>();
    // 添加请求头 文件的ContentType 动态配置 multipartFile.getContentType()
    headers.put("Content-Type", "application/octet-stream");

    String fileName = multipartFile.getOriginalFilename();

    String minFileName = minFileName(fileName);
    instance.putObject(
            PutObjectArgs.builder().bucket(strDir).object(minFileName).stream(
                    inputStream, inputStream.available(), -1) // PutObjectOptions,上传配置(文件大小,内存中文件分片大小)
                    .headers(headers)
                    .build());
    String url = endpoint.concat("/").concat(strDir).concat("/").concat(minFileName);
    // 返回生成文件名、访问路径
    return new MinIoUploadVo(strDir, fileName, minFileName, url);
}

上传文件接口

@RequestMapping(value = "/upload", method = RequestMethod.POST)
public R upload(MultipartFile file, HttpServletRequest request) throws IOException {
    String strDir = request.getParameter("bucketName") == null ? "car" : request.getParameter("bucketName");

    try {
        MinIoUploadVo uploadVo = minioService.upload(strDir, file);
        return R.ok().message("文件上传成功").data(uploadVo);
    } catch (Exception e) {
        log.error("上传文件失败,msg={}", e.getMessage());
        e.printStackTrace();
        return R.error();
    }
}

测试相关接口

image-20220312221827560

如果不能访问该地址 ,记得去开启相关权限。

image-20220312221903349

3. 问题记录

S3 API Request made to Console port. S3 Requests should be sent to API port.

image-20220312172858000

原因是配置文件里面用了Console 控制台的端口,应该使用API端口:

image-20220312173013584

4. 项目地址

更多Demo案例可以前往我的个人仓库查看 正在逐步更新中。

https://gitee.com/cl1429745331/java-coder

加载全部内容

相关教程
猜你喜欢
用户评论