1、前言
在java web编程中,目前微服务体系的框架越来越流行了,随着服务的拆分,可能我们的项目的细粒度,会变得很细。
一般的项目,基本上都会涉及到文件的存储。对于文件的存储,这个在微服务的体系下,我们可以将文件抽取出一个独立的文件微服务。然后提供相应的api(上传,下载,删除)等......
对于独立的文件微服务,我们可以根据项目的需求,使用策略模式,整合多个文件服务器,例如:阿里云Oss
、fastdfs
、minio
等。
今天我们主要讲的是minio
:
MinIO是专门为海量数据存储、人工智能、大数据分析而设计的对象存储系统。据官方介绍,单个对象最大可达5TB。非常适合储海量图片、视频、日志文件、备份数据和容器/虚拟机镜像等
- 安装部署非常简单
- 操作简单,自带ui
- 性能优秀,可以达到每秒GB级别的读写速度
- 支持主流的云原生容器化部署
- 提供多语言SDK的支持
- 参考学习文档非常全面
既然minio有这么多优点,那我们来整合一下minio吧!
2.minio部署
学习文档:minio学习文档
githug地址:minio
java sdk文档:java sdk
docker 部署文档:docker部署minio
这里提供的文档是英文的,为什么这里列出