1、什么是Minio
我们平时的学习过程可能只是把文件存储在了本地,但是在实际开发中这肯定是不现实的,所以这时候我们就用到了Minio,MinIO 是一个开源的对象存储服务器。这意味着它允许你在互联网上存储大量数据,比如文件、图片、视频等,而不需要依赖传统的文件系统。MinIO 的特点在于它非常灵活、易于使用,同时也非常强大,可以在你的应用程序中方便地集成。像这样的存储工具还有oss以及七牛等等。这里着重介绍minio开发
2、Minio安装和启动
Minio可以再docker启动,也可以在linux和windows启动
2.1docker启动minio
2.1.1下载 Minio 镜像
在浏览器中访问docker仓库地址:https://hub.docker.com/ , 输入关键词 minio/minio, 找到 Minio 镜像:
点击进去,点击 Tags 标签选项,版本你可以自己选,
2.1.2 下载 Minio 镜像
点击右侧复制命令,打开命令行,执行该命令拉取镜像:
bash
docker pull minio/minio:RELEASE.2023-09-30T07-02-29Z

镜像下载成功后,执行 docker images , 如果列表中有 minio/minio 镜像,则表示镜像下载成功了
2.1.3 新建数据挂载目录
挂载的目的是防止容器重启后,会导致数据丢失的问题。 如果只是练习的话这步可以省略
在你电脑上建个文件夹作为挂载目录
2.1.4运行 Docker Minio 容器
bash
docker run -d -p 9000:9000 -p 9090:9090 --name minio -v D:\docker\minio\data:/data -e "MINIO_ROOT_USER=admin" -e "MINIO_ROOT_PASSWORD=123456789" minio/minio:RELEASE.2023-09-30T07-02-29Z server /data --console-address ":9090"
大概解释一下上述命令各选项的含义,docker的知识大家自己可以去写一下:
docker run: 运行 Docker 容器的命令。
-d : 表示后台运行该容器;
-p 9000:9000: 将宿主机的 9000 端口映射到容器的 9000 端口。MinIO 默认的 HTTP API 端口是 9000。
-p 9090:9090: 将宿主机的 9090 端口映射到容器的 9090 端口。这是 MinIO 的 Web 控制台的端口。
--name minio: 给容器取了一个名字,这里是 "minio"。
-v D:\docker\minio\data:/data: 将宿主机上的 E:\docker\minio\data 目录映射到容器内的 /data目录。这是 MinIO 存储数据的地方。如果你希望数据在容器删除后仍然保存,可以将数据目录映射到宿主机。
-e "MINIO_ROOT_USER=admin": 设置 MinIO 的管理员用户名为 "admin"。这是用于 MinIO Web 控制台和 API 的初始管理员用户名。
-e "MINIO_ROOT_PASSWORD=123456789": 设置 MinIO 的管理员密码为 "123456789"。这是用于 MinIO Web 控制台和 API 的初始管理员密码。
minio/minio:RELEASE.2023-09-30T07-02-29Z: 这是 MinIO 的 Docker 镜像版本。
server /data --console-address ":9090": 启动 MinIO 服务器,并将数据存储在容器内的/data目录。--console-address ":9090"表示 MinIO 的Web 控制台将在容器的 9090 端口上运行。
2.2 windows启动minio
windows启动只需要在官网下载zip包解压如下:
进入bin 然后进入终端输入命令即可直接启动:
bash
.\minio.exe server D:\minio-data --console-address ":9001"

2.3.访问 Minio 控制台
浏览器访问地址 http://localhost:9090 ,可访问 MinIO 的 Web 控制台
2.4.使用Minio
2.4.1创建asskey

2.4.2 创建桶

这里注意一点,需要点击设置把桶调成公共模式,不然外界是访问不到url的
这里可以手动上传图片,像这样就成功了
3 Minio图片上传接口开发:
3.1添加 Minio 依赖
java
<dependency>
<groupId>io.minio</groupId>
<artifactId>minio</artifactId>
<version>8.2.1</version>
</dependency>
3.2 添加 Minio 配置
创建application.yml 添加配置
xml
minio:
endpoint: http://127.0.0.1:9000
accessKey: xxxx
secretKey: xxxxx
bucketName: test
ip填你自己的
endpoint: http://127.0.0.1:9000:指定 MinIO 服务器的地址。实际部署时,您需要将它替换为您 MinIO 服务器的地址。
accessKey: admin:运行容器时,指定的接入 key。
secretKey: 123456789:运行容器时,指定的秘钥 key。
bucketName: weblog:存储桶(bucket)的名称。
3.3. 新增 Minio 配置类
java
@Configuration
@ConfigurationProperties(prefix = "minio")
@Data
public class MinioConfig {
private String endpoint;
private String accessKey;
private String secretKey;
private String bucketName;
@Bean
public MinioClient minioClient() {
return MinioClient.builder()
.endpoint(endpoint)
.credentials(accessKey, secretKey)
.build();
}
}
配置类的前缀需要指定为 minio, 且字段名要与yml文件一致。
3.4. 新增 Minio 客户端配置
java
@Configuration
@ConfigurationProperties(prefix = "minio")
@Data
public class MinioConfig {
private String endpoint;
private String accessKey;
private String secretKey;
private String bucketName;
@Bean
public MinioClient minioClient() {
return MinioClient.builder()
.endpoint(endpoint)
.credentials(accessKey, secretKey)
.build();
}
}
3.5封装图片上传工具类
java
@Component
@Slf4j
public class MinioUtil {
@Autowired
private MinioClient minioClient;
@Autowired
private MinioConfig minioConfig;
public String uploadFile(MultipartFile file) throws Exception {
if (file == null || file.getSize() == 0) {
log.error("==> 上传文件异常:文件大小为空 ...");
throw new RuntimeException("文件大小不能为空");
}
//文件的原始名称
String originalFilename = file.getOriginalFilename();
//文件的ContentType
String contentType = file.getContentType();
// 生成存储对象的名称(将 UUID 字符串中的 - 替换成空字符串)
String key = UUID.randomUUID().toString().replace("-", "");
// 获取文件的后缀,如 .jpg
String suffix = originalFilename.substring(originalFilename.lastIndexOf("."));
// 拼接上文件后缀,即为要存储的文件名
//拼写图片路径
//拼写图片路径
String fileName = new SimpleDateFormat("yyyy/MM/dd").format(new Date())
+"/"+ UUID.randomUUID().toString()+originalFilename.substring(originalFilename.lastIndexOf("."));
// String fileName = String.format("%s%s", key, suffix);
// 上传文件至 Minio
minioClient.putObject(PutObjectArgs.builder()
.bucket(minioConfig.getBucketName())
.object(fileName)
.stream(file.getInputStream(), file.getSize(), -1)
.contentType(contentType)
.build());
// 返回文件的访问链接
String url = String.format("%s/%s/%s", minioConfig.getEndpoint(), minioConfig.getBucketName(), fileName);
return url;
}
}
3.6编写Controller方法
java
@RestController
@Slf4j
@RequestMapping("/api/file")
public class FileController {
@Autowired
private MinioService minioService;
@PostMapping("/upload")
public Result uploadFile(@RequestParam MultipartFile file) {
return minioService.uploadFile(file);
}
}
3.7编写Service实现
java
@Service
@Slf4j
public class MinioService {
@Autowired
private MinioUtil minioUtil;
/**
* 上传文件
*
* @param file
* @return
*/
public Result uploadFile(MultipartFile file) {
try {
// 上传文件
String url = minioUtil.uploadFile(file);
// 构建成功返参,将图片的访问链接返回
return Result.OK(url);
} catch (Exception e) {
// 手动抛出业务异常,提示 "文件上传失败"
log.error("文件上传失败:{}",file);
e.printStackTrace();
return null;
}
}
}
到这里就写完了,谢谢阅读