百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

一个轻量级的对象存储系统——Minio

bigegpt 2024-08-11 14:15 31 浏览

概要

随着网络存储技术的逐渐成熟,相信很多人会使用一些大厂的对象存储服务,即 OSS,如某某云的 OSS 服务,如不知道什么是对象存储服务,请先自行搜索一下。有了 OSS,我们就不用把数据放到本地,通过网络,随时随地访问我们需要的数据。

出于安全方面的考虑,部分公司会自行搭建 OSS 系统,或者是个人学习,也需要用到 OSS。很多大型企业都会用到类似 ceph 的存储服务,但是 ceph 学习和部署成本太大,没有经过几年的技术浸泡,是很难切入去的。在这样的情况下,一款越来越火的轻量级对象存储系统就这样诞生了,它就是 Minio。

Minio 是一个基于 Apache License v2.0 开源协议的对象存储服务。它兼容亚马逊 S3 云存储服务接口,非常适合于存储大容量非结构化的数据,例如图片、视频、日志文件、备份数据和容器/虚拟机镜像等,而一个对象文件可以是任意大小,从几 kb 到最大 5T 不等。是一个非常轻量的服务,可以很简单地和其他应用结合,类似 NodeJS、Redis 或者 MySQL。

Minio 既支持单机版部署,让我们去学习研究,又支持分布式部署,承担我们生产环境的服务。两种部署方式都非常简单,其中分布式部署还提供了纠删码功能来降低数据丢失的风险。确实是一款可盐可甜的优秀产品。

下面我们来介绍一下minio的安装方式。


安装

MinIO的安装方式有很多,支持docker容器安装、二进制方式安装,这里我们使用二进制方式安装。

wget https://dl.min.io/server/minio/release/linux-amd64/minio
//1.下载minio源码包


chmod +x minio
//2.更改权限

./minio server /data
//启动服务 /data为我们自定义的文件目录

如上图所示,我们已经成功运行了一个单机版的 Minio 服务,下面介绍一下 Minio 单机版和分布式的部署方式。


分布式部署

在生产环境中,我们往往会采用分布式方式部署,这样能降低服务负载,并且Minio 在分布式上提供了数据容灾的方式,下面我们来看看分布式的部署方式。

需要注意以下几点:
1) 分布式 Minio 里所有的节点需要有同样的 access秘钥 和 secret秘钥,这样节点才能建立联接。需要在执行 minio server 命令之前,先将 access秘钥 和 secret秘钥 export 成环境变量。
2) 分布式 Minio使用的磁盘里必须是干净的,里面没有数据。
3) 分布式 Minio 里的节点时间差不能超过3秒。
4) 分布式部署至少需要4个节点,否则启动会报错。

在集群所有服务器上执行相同命令

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 支持浏览器访问,在浏览器中输入服务器提供的http://{你的ip地址}:9000

如上图所示,可以在浏览器上看到我们的服务信息,例如有多少个桶,桶里面对象的列表,web中提供了一些简单的操作,例如创建文件桶,上传文件。


其他方式访问

1、亚马逊S3协议
Minio 本人觉得最好用的地方就是全面兼容亚马逊 S3 协议,如果对接的 OSS 服务是 S3 协议,那么我们无需改动任何代码,搭建好 Minio 即可实现无缝对接,开箱即用。

2、SDK API
Minio 提供了很多语言的 SDK 跟 API 支持:javascript,Java,python,Golang、.Net,我们可以到官网下载 SDK 使用 API 进行对接。

3、MinIO客户端
Minio Client (mc)为ls,cat,cp,mirror,diff,find等 UNIX命令 提供了一种替代方案。它支持文件系统和兼容 Amazon S3 的云存储服务(AWS Signature v2和v4)。Minio 服务端中并没有自带客户端,所以我们需要安装配置完客户端后才能使用。

具体的命令可自行查阅官网文档~


总结

对于数据不上云的公司或者需要学习 OSS 的童鞋,都可以拿来即用,Minio 确实给我们带来了好多方便,轻量级安装部署,无缝对接亚马孙S3,数据纠错机制,对K8S友好的支持,优点真是越数越多。本人觉得不足之处就是不能热扩容,希望后续 Minio 的开发者能考虑到这一点。


下期会给大家介绍Vue2与Vue3的响应式区别,敬请期待~

欢迎各位关注、留言,大家的支持就是我的动力!

相关推荐

5分钟调色大片的方法(5分钟调色大片的方法有哪些)

哈喽大家好。在大家印象中一定觉得ps非常难学非常难。大家不要着急,小编的教学都是针对ps零基础的同学的,而且非常实用哦。只要大家跟着图文练习一两遍,保证大家立马学会~!好了,废话少说,下面开始我们今天...

闪白特效原来是这么用的(闪白特效怎么使用)

作者|高艳侠订阅|010-86092062闪白特效是影视作品中应用比较多的效果之一,那么具体该在哪些场景使用闪白特效?具体该如何操作?下面就以AdobePremiere(以下简称PR)为例,...

ppt常用小图标去哪里找?3个矢量素材网站推荐!

ppt是一个注重可视化表达的演示载体,除了高清图片,ppt中另一类常用的素材是各种小图标,也叫矢量图标,巧妙运用小图标能提升整体美观度和表现力,那么ppt常用小图标去哪里找呢?为方便各位快速找到合适的...

有什么好用的截图录屏工具?试试这9款

经常有朋友反馈苦于缺乏截屏和录屏的趁手工具,本期我们分享几个相当好用的截屏和录屏工具,希望能帮到大家。ScreenToGifScreenToGif是一款免费且开源的录屏工具。此款工具最大的特点是可以...

配色苦手福音!专业快速色环配色PS插件

今天橘子老师给的大家介绍的是一款快速配色的插件,非常强大配色苦手福音来啦!(获取方式见文末)【插件介绍】配色在后期设计中占有主导地位,好的配色能让作品更加抢眼Coolorus这款专业的配色插件,能够...

如何用PS抠主体?(ps怎么抠主体)

1.主体法抠图-抠花苞和花梗导入一张荷花苞的照片,点击上图中顶部“选择”菜单栏,下拉单击“主体”。可以看到,只有花苞被选中,但是花梗并没有被选中。接下来单击上图中左侧工具栏的“快速选择工具”,上图中顶...

2799元的4K电视,有保障吗?(买4k电视机哪个品牌好)

在上一期《电脑报》的3·15专题报道中,我们揭露了一款不靠谱的42英寸4K智能电视——TCLD42A561U。这款售价2699元的4K智能电视不仅4K画质方面存在严重问题,而且各种功能和应用体验也不理...

苹果电脑的Touch Bar推出一段时间了 这款工具可以帮你开发适用于它的APP

距离苹果推出带有TouchBar的MacBookPro已经有一段时间了,除了那些像Adobe、Google和Microsoft大公司在开发适用于TouchBar的应用之外,其实还有很多独立的开...

如魔法般吸取颜色的桌灯(如魔法般吸取颜色的桌灯叫什么)

色彩为生活带来的感官刺激,逐渐被视为理所当然。一盏桌灯运用它的神奇力量,将隐藏于物件中的颜色逐一释放,成为装点环境的空间魔法师。ColorUp是一款可以改变颜色的吸色台灯,沿用传统灯泡的造型,融入了拾...

一篇文章带你用jquery mobile设计颜色拾取器

【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...

ps拾色器快捷键是什么?(ps2019拾色器快捷键)

ps拾色器快捷键是什么?文章末尾有获取方式,按照以下步骤就能自动获得!学会制作PS特效需要一定程度的耐心和毅力。初学者可以从基本的工具和技术开始学习,逐渐提高他们的技能水平。同时,观看更多优秀的特效作...

免费开源的 Windows 截图录屏工具,支持 OCR 识别和滚动截图等

功能很强大、安装很小巧的免费截图、录屏工具,提供很多使用的工具来帮我么能解决问题,推荐给大家。关于ShareXShareX是一款免费的windows工具,起初是一个小巧的截图工具,经过多年的迭...

入门到精通系列PS教程:第13篇 · 拾色器、颜色问题说明及补充

入门到精通系列PS教程:第13篇·拾色器、颜色问题说明及补充作者|侯潇问题说明我的第12篇教程里,有个小问题没有说清楚。要说是错误,又不算是错误,只是没有说准确。写完那篇教程后,因为已经到了深...

PS冷知识:用吸管工具吸取屏幕上的任意颜色

今天,我们给大家介绍PS中的一个冷知识:用吸管工具可以吸取屏幕上的任意颜色。其实,操作起来是非常简单的。大多数情况下,我们认为,PS的吸管工具只能吸取PS软件作图区域范围内的颜色,最多加上画布四周的...

Windows 11 将提供内置颜色选择器工具

Windows11内置了颜色选择器,可以扫描并识别屏幕上的颜色并生成颜色代码。此外,微软还利用人工智能技术,让屏幕上的文本扫描和选择变得更加便捷。这两项功能均已在SnippingToolv1...