使用MinIO搭建对象存储服务

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用MinIO搭建对象存储服务相关的知识,希望对你有一定的参考价值。

参考技术A

之前我使用的是阿里云OSS,想了解阿里云OSS的小伙伴参考SpringBoot整合阿里云OSS

docker run -d -p 9000:9000 -p 9001:9001 --name minio -e MINIO_ACCESS_KEY=qbb -e MINIO_SECRET_KEY=startqbb -v /opt/minio/data:/data -v /opt/minio/config:/root/.minio minio/minio server /data --console-address ":9000" --address ":9001"

注意:9000是我们浏览器访问控制台的端口,而9001是SDK代码操作的端口

yum -y install ntp ntpdate :安装插件工具
hwclock --systohc :同步时间
docker restart minio镜像ID :重启镜像

MinIO 搭建使用

MinIO简介

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

安装及部署

MinIO的安装方式有很多,这里我们使用它在Docker环境下的安装方式。

  • 下载MinIO的Docker镜像:
docker pull minio/minio
  • 在Docker容器中运行MinIO,这里我们将MiniIO的数据和配置文件夹挂在到宿主机上:
docker run -p 9090:9000 --name minio   -v /etc/localtime:/etc/localtime   -v /data/minio/data:/data   -v /data/minio/config:/root/.minio   -d minio/minio server /data
  • 运行成功后,访问该地址来登录并使用MinIO,默认Access Key和Secret都是minioadmin:http://localhost:9090

技术图片

上传文件及使用

通过使用MinIO的网页端即可完成文件的上传下载功能,下面我们以图片上传下载为例来演示下该功能。

  • 在存储文件之前,我们需要新建一个存储桶:

技术图片

  • 存储桶创建完成后,通过上传按钮可以上传文件,这里我们上传一张图片:

技术图片

  • 图片上传完成后,我们可以通过拷贝链接按钮来获取图片访问路径,但是这只是个临时的访问路径:

技术图片

  • 要想获取一个永久的访问路径,需要修改存储桶的访问策略,我们可以点击存储桶右上角的编辑策略按钮来修改访问策略;

技术图片

  • 这里有三种访问策略可以选择,一种只读、一种只写、一种可读可写,这里我们选择只读即可,但是需要注意的是,访问前缀需要设置为*.*,否则会无法访问;

技术图片

  • 设置完成后,我们只需要通过拷贝链接中的前一串路径即可永久访问该文件;

MinIO客户端的使用

虽然MinIO的网页端管理已经很方便了,但是官网还是给我们提供了基于命令行的客户端MinIO Client(简称mc),下面我们来讲讲它的使用方法。

常用命令

下面我们先来熟悉下mc的命令,这些命令和Linux中的命令有很多相似之处。

命令作用
ls 列出文件和文件夹
mb 创建一个存储桶或一个文件夹
cat 显示文件和对象内容
pipe 将一个STDIN重定向到一个对象或者文件或者STDOUT
share 生成用于共享的URL
cp 拷贝文件和对象
mirror 给存储桶和文件夹做镜像
find 基于参数查找文件
diff 对两个文件夹或者存储桶比较差异
rm 删除文件和对象
events 管理对象通知
watch 监听文件和对象的事件
policy 管理访问策略
session 为cp命令管理保存的会话
config 管理mc配置文件
update 检查软件更新
version 输出版本信息

安装及配置

由于MinIO服务端中并没有自带客户端,所以我们需要安装配置完客户端后才能使用,这里以Docker环境下的安装为例。

  • 下载MinIO Client 的Docker镜像:
docker pull minio/mc
  • 在Docker容器中运行mc:
docker run -it --entrypoint=/bin/sh minio/mc
  • 运行完成后我们需要进行配置,将我们自己的MinIO服务配置到客户端上去,配置的格式如下:
mc config host add <ALIAS> <YOUR-S3-ENDPOINT> <YOUR-ACCESS-KEY> <YOUR-SECRET-KEY> <API-SIGNATURE>
  • 对于我们的MinIO服务可以这样配置:
mc config host add minio http://localhost:9000 minioadmin minioadmin S3v4

常用操作

  • 查看存储桶和查看存储桶中存在的文件:
# 查看存储桶
mc ls minio
# 查看存储桶中存在的文件
mc ls minio/blog

技术图片

  • 创建一个名为test的存储桶:
mc mb minio/test
  • 共享avatar.png文件的下载路径:
mc share download minio/blog/avatar.png
  • 查找blog存储桶中的png文件:
mc find minio/blog --name "*.png"
  • 设置test存储桶的访问权限为只读
# 目前可以设置这四种权限:none, download, upload, public
mc policy set download minio/test/
# 查看存储桶当前权限
mc policy list minio/test/

参考资料

详细了解MinIO可以参考官方文档:https://docs.min.io/cn/minio-quickstart-guide.html

以上是关于使用MinIO搭建对象存储服务的主要内容,如果未能解决你的问题,请参考以下文章

分布式存储Minio集群环境搭建

【Minio】基于AWS S3协议搭建个人云存储服务

分布式存储Minio集群环境搭建

MinIO 分布式集群搭建

MinIO 搭建

分布式minio搭建指南