[TOC]linux
对象存储服务(Object Storage Service,OSS)是一种海量、安全、低成本、高可靠的云存储服务,适合存听任意类型的文件。容量和处理能力弹性扩展,多种存储类型供选择,全面优化存储成本。git
在项目开发过程当中,咱们会产生大量的对象数据,包括:日志文件,数据库脚本文件、安装包,容器镜像,图像、视频等等,咱们不只仅是须要有一个集中的地方来存储,还须要能基于 Web 的方式来访问它们,以往咱们有如下几种方法来解决:github
本篇文章主要介绍下其中的Minio方案算法
Minio是GlusterFS创始人之一Anand Babu Periasamy发布新的开源项目。Minio兼容Amason的S3分布式对象存储项目,采用Golang实现,客户端支持Java,Python,Javacript, Golang语言。docker
Minio是创建在云原生的基础上;有分布式和共享存储等功能;旨在多租户环境中以可持续的方式进行扩展的对象存储服务。它最适合存储非结构化数据,如:照片、视频、日志文件、容器/虚拟机/映像等,单次存储对象的大小最大可达5TBshell
左边是 MINIO 集群的示意图,整个集群是由多个角色彻底相同的节点所组成的。由于没有特殊的节点,因此任何节点宕机都不会影响整个集群节点之间的通讯。经过 rest 跟 RPC 去通讯的,主要是实现分布式的锁跟文件的一些操做数据库
右边这张图是单个节点的示意图,每一个节点都单独对外提供兼容 S3 的服务json
以下图,每一行是一个机器节点,这里有32个集群,每一个节点里有一个小方块,咱们称之为Drive,Drive可简单地理解为磁盘。一个节点有32个Drive,至关于32个磁盘。后端
Set是一组Drive的集合,全部红色标识的Drive组成了一个Set。浏览器
一个对象存储在一个Set上; 一个集群划分为多个Set
一个Set包含的Drive数量是固定的, 默认由系统根据集群规模自动计算得出 MINIO_ERASURE_SET_DRIVE_COUNT
一个SET中的Drive尽量分布在不一样的节点上
Minio 提供了两种部署方式:单机部署和分布式,两种部署方式都很是简单,其中分布式部署还提供了纠删码功能来下降数据丢失的风险
wget
https://dl.min.io/server/minio/release/linux-amd64/minio
`
chmod +x minio
./minio server /data #
若/data
目录不存在,要新建一个`
mkdir /data/minio-data&&mkdir /data/minio-config # 建立一个数据存储目录 docker run -p 9000:9000 --name minio \ -d --restart=always \ -e "MINIO_ACCESS_KEY=admin" \ -e "MINIO_SECRET_KEY=admin123456" \ -v /data/minio-data:/data \ -v /data/minio-config:/root/.minio \ minio/minio server /data
http://localhost:9000/ 便可登录Minio 的管理界面
单机Minio服务存在单点故障,相反,若是是一个有 m 台服务器, n 块硬盘的分布式Minio,只要有 m/2 台服务器或者 m*n/2 及更多硬盘在线,你的数据就是安全的。
例如,一个16节点的Minio集群,每一个节点200块硬盘,就算8台服務器宕机,即大概有1600块硬盘,这个集群仍然是可读的,不过你须要9台服務器在线才能写数据。
export MINIO_ACCESS_KEY=<ACCESS_KEY>
export MINIO_SECRET_KEY=<SECRET_KEY>
minio server
http://host
{1...n}/export{1...m}
http://host
{1...o}/export{1...m}
固然若是咱们只有一台机器,可是想用纠删码的功能,也能够直接配置使用多个本地盘minio server /data1 /data2 /data3 ... /data8
默认的配置目录是 ${HOME}/.minio,你可使用--config-dir命令行选项重写之。MinIO server在首次启动时会生成一个新的config.json,里面带有自动生成的访问凭据。minio server --config-dir /etc/minio /data
TLS证书存在${HOME}/.minio/certs目录下,你须要将证书放在该目录下来启用HTTPS
只能经过环境变量MINIO_ROOT_USER 和 MINIO_ROOT_PASSWORD 更改MinIO的admin凭据和root凭据。使用这两个值的组合,MinIO加密存储在后端的配置
export MINIO_ROOT_USER=minio
export MINIO_ROOT_PASSWORD=minio13
minio server /data
将对象数据存储到 Minio 中有如下几种方式:
• 经过 MINIO CLIENT
• 经过 MINIO SDK 目前支持的语言包括:Go,Java,Node.js,Python,.NET
• 经过浏览器访问 Web 管理界面,在管理界面中上传和下载对象
• 若是你有存储目录 minio-data 的帐号和访问权限,能够直接使用 SCP 命令将数据写入磁盘
wget https://dl.min.io/client/mc/release/linux-amd64/mc chmod +x mc
MinIO Client (mc)为ls,cat,cp,mirror,diff,find等UNIX命令提供了一种替代方案。它支持文件系统和兼容Amazon S3的云存储服务(AWS Signature v2和v4)。
ls
`列出文件和文件夹。``
mb 建立一个存储桶或一个文件夹。
cat 显示文件和对象内容。
pipe 将一个
STDIN重定向到一个对象或者文件或者
STDOUT。
share 生成用于共享的
URL。
cp 拷贝文件和对象。
mirror 给存储桶和文件夹作镜像。
find 基于参数查找文件。
diff 对两个文件夹或者存储桶比较差别。
rm 删除文件和对象。
events 管理对象通知。
watch 监听文件和对象的事件。
policy 管理访问策略。
session 为
cp命令管理保存的会话。
config 管理
mc配置文件。
update 检查软件更新。
version `输出版本信息。
列出Mino服务端
命令行建立bucket
// 构造访问对象 var minio = new MinioClient("localhost:9000","accessKey","secretKey"); // 输出全部的 Buckets var rs = minio.ListBucketsAsync(); foreach (varbucket in rs.Result.Buckets) { Console.Out.WriteLine(bucket.Name + " " + bucket.CreationDateDateTime); } // 存储对象 var bucketName = "logs"; var objectName = "logs.zip"; var filePath = "c:\\logs.zip"; var contentType = "application/zip"; minio.PutObjectAsync(bucketName, objectName, filePath, contentType); // 获取对象 var find = minio.GetObjectAsync(bucketName, objectName)