【从零开始学习Minio | 第一篇】快速介绍什么是Minio

news/2024/10/19 7:34:16/

前言:

在当今数字化时代,数据的存储和管理已经成为了企业发展中的关键一环。随着数据量的不断增长和数据安全性的日益受到重视,传统的数据存储解决方案往往面临着诸多挑战。为了应对这些挑战,云存储技术应运而生,并在各个领域展现出了巨大的潜力和优势。

在云存储技术中,MinIO作为一个开源的对象存储服务器,正逐渐成为了行业内的热门选择。其高度可扩展、高性能、安全可靠的特性,使其在云原生应用、大数据分析、备份和归档等场景中受到了广泛关注和应用。

目录

前言:

Minio%EF%BC%9A-toc" style="margin-left:0px;">什么是Minio

Minio%E7%9A%84%E5%9F%BA%E7%A1%80%E6%A6%82%E5%BF%B5%EF%BC%9A-toc" style="margin-left:0px;">Minio的基础概念:

Minio%E5%9C%A8windows%E4%B8%AD%E7%9A%84%E4%B8%8B%E8%BD%BD%EF%BC%9A-toc" style="margin-left:0px;">Minio在windows中的下载:

Minio%E7%9A%84%E4%BC%98%E7%82%B9%EF%BC%9A-toc" style="margin-left:0px;">Minio的优点:

总结:


 

在之前的项目中,我们搭建了一个web版本的云盘网站,但是这个项目在存储用户文件的时候,我们只是简单的利用IO把文件保存在的本地。

【Easy云盘】_我是一盘牛肉的博客-CSDN博客icon-default.png?t=N7T8https://blog.csdn.net/fckbb/category_12611250.html?spm=1001.2014.3001.5482而在这里我们提出了一种新的优化方案:那就是基于Minio进行存储

而我们之所以不选择直接把用户文件存储在OSS这种云对象存储服务平台上,主要还是因为费用太高,而且后期不易转移。

如果在后期我们想要搭建自己的存储服务器进行存储文件,想要把所有文件数据从OSS这类平台上拉下来的时候。按照OSS的计费标准1TB大概是500元左右,而这对于云盘来讲确实是一个比较高的费用了。

所以对于中小型企业来讲,如果不选择存储上云,那么Minio是一个不错的选择,Minio除了直接作为对象存储使用,还可以作为云上对象存储服务的网关层,无缝对接到Amazon S3,MicroSoft Azure。

在中国,有很多互联网大厂都在使用Minio产品,例如阿里巴巴,百度,华为等。

Minio%EF%BC%9A">什么是Minio

MinIO 是一个开源的对象存储服务器,旨在提供高性能、可扩展、持久性的存储解决方案。它允许用户通过简单的 HTTP/REST API 来存储和检索任意类型的数据,例如图片、视频、文档等。

MinIO 设计用于大规模的数据存储和分析任务,具有以下特点:

  1. 高性能 MinIO 利用现代硬件和网络技术,提供了高速的数据传输和处理能力。其并行计算和多线程技术可以最大程度地利用系统资源,实现快速的数据存储和访问。

  2. 可扩展性 MinIO 是一个分布式存储系统,可以轻松地扩展存储容量和性能。用户可以通过添加新的存储节点来实现横向扩展,满足不断增长的数据存储需求。

  3. 持久性 MinIO 支持数据的多副本复制和分布式存储,确保数据的高可用性和持久性。即使某个节点发生故障,系统仍然可以继续提供服务,保证数据安全和可靠性。

  4. 云原生支持 MinIO 可以轻松地集成到云原生架构中,支持容器化部署和微服务架构。它与 Kubernetes、Docker 等平台完美配合,适合在云环境中构建高可用、可扩展的存储基础设施。

  5. 开源和灵活性 MinIO 是一个开源项目,拥有活跃的社区支持和持续的更新迭代。它提供了丰富的 API 和插件机制,可以轻松地与其他系统集成,满足不同场景下的需求。

总的来说,MinIO 提供了一个高性能、可扩展、持久性的对象存储解决方案,适用于各种大规模数据存储和分析任务,成为许多企业和开发者的首选存储平台。

Minio%E7%9A%84%E5%9F%BA%E7%A1%80%E6%A6%82%E5%BF%B5%EF%BC%9A">Minio的基础概念:

在 MinIO 中,有一些重要的概念需要理解,包括对象(Object)桶(Bucket)驱动器(Drive)集合(Set)。以下是对这些概念的介绍:

  1. 对象(Object) 在 MinIO 中,对象是存储在对象存储系统中的基本数据单元。每个对象都由数据、元数据和唯一的标识符组成。对象可以是任何类型的数据,例如文件、图片、视频等。对象存储使用键(Key)来唯一标识和检索对象,而不是使用传统的文件路径。对象存储提供了高度可扩展性和持久性,适用于大规模的数据存储和分析任务。

  2. 桶(Bucket) 桶是 MinIO 中用于组织和管理对象的容器。每个桶都有一个唯一的名称,在同一个 MinIO 实例中,桶名称必须是唯一的。用户可以通过桶来对对象进行逻辑分组,例如按照项目、部门或者应用程序来创建不同的桶。桶可以设置访问权限控制,以控制谁可以访问其中的对象以及执行何种操作。

  3. 驱动器(Drive) 驱动器是 MinIO 中用于存储数据的物理设备或者存储后端。MinIO 可以将一个或多个驱动器组合成一个存储池(Storage Pool),用于存储对象数据。驱动器可以是本地硬盘、网络存储设备、云存储服务等。通过添加新的驱动器,用户可以扩展 MinIO 的存储容量和性能。

  4. 集合(Set) 集合是 MinIO 中用于管理存储策略和数据复制的概念。集合定义了一组具有相同特性或者策略的桶,例如数据的复制级别、存储类别等。用户可以通过创建集合来对一组桶进行统一的管理和配置,简化数据管理和维护操作。

综上所述,对象、桶、驱动器和集合是 MinIO 中的重要概念,理解它们可以帮助用户更好地使用和管理 MinIO 存储系统,实现高效的数据存储和管理。

Minio%E5%9C%A8windows%E4%B8%AD%E7%9A%84%E4%B8%8B%E8%BD%BD%EF%BC%9A">Minio在windows中的下载:

首先我们要先进入minio的中文官方网站:

MinIO | 用于AI的S3 & Kubernetes原生对象存储icon-default.png?t=N7T8https://minio.org.cn/

在这里我们可以点击下载进入下载界面:

我的电脑是windows的,所以我们在这里就展示一下Windows环境下的安装和使用。

在搜索栏输入这段url,就会进行下载,等待下载完全之后,我们就会得到这样一个文件:

 

这就证明我们的minio服务已经安装成功,现在我们如果想要在电脑上启动这个服务,首先要创建一个文件夹用来存放minio的存储的各种数据,这里我们选择在同级目录下创建了一个名字叫做data的文件夹:

 

之后我们在当前窗口打开cmd窗口,输入:

minio.exe server D:\all bianyiqi\minio\data

 就可以启动该服务:

 根据指引访问地址就可以了,我们就会进入这个界面:

账号和密码都是  minioadmin 。这样我们就可以进入使用界面:

在这里我们就可以创建桶用来进行文件存储了。后续我们会讲解Spring boot集成Minio实现文件的下载等功能。

Minio%E7%9A%84%E4%BC%98%E7%82%B9%EF%BC%9A">Minio的优点:

  1. 高性能 MinIO 使用了一系列优化技术,包括并行处理、分布式架构和异步 IO 等,以提供高性能的数据存储和检索。它能够在大规模数据处理和分析任务中实现低延迟和高吞吐量,满足各种性能要求。

  2. 高可用性 MinIO 支持分布式部署和数据复制,能够实现数据的冗余存储和自动故障转移。即使在单个节点或者驱动器故障的情况下,系统仍然能够保持可用性,并且对用户来说是透明的,不会影响数据的访问和操作。

  3. 弹性扩展 MinIO 的架构设计允许用户根据需要轻松地扩展存储容量和性能。用户可以添加新的节点和驱动器来扩展集群,实现无缝的水平扩展,以满足不断增长的数据需求。

  4. 灵活性 MinIO 提供了丰富的 API 和客户端工具,支持各种编程语言和应用场景。用户可以通过标准的 S3 API 访问和管理 MinIO 存储,也可以使用其他协议和工具进行集成和开发。

  5. 安全性 MinIO 支持多种安全功能,包括访问权限控制、数据加密、身份验证和认证等。用户可以根据需要对桶和对象设置访问权限,以保护数据的安全性和隐私性。

  6. 低成本 MinIO 是一个开源软件,用户可以免费获取并自由使用。它还可以运行在廉价的硬件设备上,并且具有低延迟和高效率的特点,有助于降低存储成本和运营成本。

总结:

        MinIO 提供了一种高效、可靠且灵活的解决方案,用于构建现代化的文件存储和管理系统。通过 MinIO,用户可以轻松地搭建分布式对象存储系统,实现高性能的文件存储和检索,并且可以根据需求动态扩展存储容量和性能。同时,MinIO 提供了丰富的 API 和客户端工具,支持多种编程语言和开发框架,使开发者能够更灵活地集成存储功能到他们的应用程序中。此外,MinIO 还注重安全性,提供了多种安全功能,包括数据加密、访问控制和身份验证,以保护存储在系统中的文件安全。

如果我的内容对你有帮助,请点赞,评论,收藏。创作不易,大家的支持就是我坚持下去的动力!

 


http://www.ppmy.cn/news/1457759.html

相关文章

go Gin项目实战

Gin项目实战 Gin博客项目-项目架构Gin博客项目-集成gormGin博客项目-集成Bootstrap创建用户表单Gin 博客项目-实现控制器和路由Gin 博客项目-设计静态页面Gin 博客项目-用户注册Gin 博客项目-用户登录Gin 博客项目-集成markdown编辑器Gin 博客项目-创建博客模型和DAOGin 博客项…

Chrome命令大师:揭秘浏览器中的隐藏神器,提升你的上网效率!

Google Chrome是一款功能强大的浏览器,除了常规的网页浏览功能外,它还提供了许多实用的命令,可以帮助我们更高效地使用浏览器。本文将详细介绍一些常用的Chrome浏览器命令,包括它们的介绍、命令或语法、作用以及使用方法等。 打开…

【Ansiable】ansible的模块和主机清单

Ansible Ansible是一个基于Python开发的配置管理和应用部署工具,现在也在自动化管理领域大放异彩。它融合了众多老牌运维工具的优点,Pubbet和Saltstack能实现的功能,Ansible基本上都可以实现。 Ansible能批量配置、部署、管理上千台主机。比…

数据库数据恢复—Sql Server数据库文件丢失丢失怎么恢复数据?

数据库数据恢复环境: 5块硬盘组建一组RAID5阵列,划分LUN供windows系统服务器使用。windows系统服务器内运行了Sql Server数据库,存储空间在操作系统层面划分了三个逻辑分区。 数据库故障: 数据库文件丢失,主要涉及3个…

DDD架构理论详解

文章目录 一、概念入门1. 概念简介2. DDD的核心理念3. 范式4. 模型5. 框架6. 方法论7. 软件设计的主要活动 二、DDD核心理论1. Domain领域层都包含什么?2. 聚合、实体和值对象3. 仓储,封装持久化数据4. 适配(端口),调用…

echarts学习笔记:柱状图+雷达图+双环形图+地图可视化+数据传递关系图+关键词条图+数据总览图+AntV/G2/DataV

GitHub - lgd8981289/imooc-visualization: https://www.bilibili.com/video/BV1yu411E7cm/?vd_source391a8dc379e0da60c77490e3221f097a 课程源码 国内echarts镜像站:ISQQW.COM x ECharts 文档(国内同步镜像) - 配置项 echarts图表集&…

怎么在家访问公司内网?

在当前的疫情情况下,越来越多的公司开始允许员工在家办公,这就需要解决一个问题:如何在家访问公司的内网资源呢?今天我将介绍一种解决方案——使用【天联】组网,它具有许多优势。 【天联】组网的优势 无网络限制&#…

python 打包为exe可执行程序

近期因为需要做文字识别,应用ocr 所以每次都需要部署环境,然后打算做成exe,遇到问题做一总结。 pyinstaller -D --hidden-importpaddleocr testflask.py 生成exe paddleocr 和pyinstaller 安装不做说明。 No such file or directory: …