01.minio基本介绍搭建使用

MinIO 是一款基于 Go 语言的高性能、可扩展、云原生支持、操作简单、开源的分布式对象存储产品。

官网:https://min.io/

特点

  • 高性能:作为高性能对象存储,在标准硬件条件下它能达到55GB/s的读、35GG/s的写速率

  • 可扩容:不同MinIO集群可以组成联邦,并形成一个全局的命名空间,并跨越多个数据中心

  • 云原生:容器化、基于K8S的编排、多租户支持

  • Amazon S3兼容:Minio使用Amazon S3 v2 / v4 API。可以使用Minio SDK,Minio Client,AWS SDK和AWS CLI访问Minio服务器。

  • 可对接后端存储: 除了Minio自己的文件系统,还支持DAS、 JBODs、NAS、Google云存储和Azure Blob存储。

  • SDK支持: 基于Minio轻量的特点,它得到类似Java、Python或Go等语言的sdk支持

  • Lambda计算: Minio服务器通过其兼容AWS SNS / SQS的事件通知服务触发Lambda功能。支持的目标是消息队列,如Kafka,NATS,AMQP,MQTT,Webhooks以及Elasticsearch,Redis,Postgres和MySQL等数据库。

  • 有操作页面

  • 功能简单: 这一设计原则让MinIO不容易出错、更快启动

  • 支持纠删码:MinIO使用纠删码,在最高冗余度配置下,即使丢失1/2的磁盘也能恢复数据

相关名词概念

Object:存储到minio的基本对象,如文件,字节流等。

Bucket(桶):用来存储Object的逻辑空间。每个Bucket之间的数据是互相隔离的。对于客户端而言,就相当于存放文件的顶层文件夹。

Drlve(驱动器):存储数据的磁盘,在MinIO启动时,以参数的方式传入。MinIO中所有的对象数据都会存在Drive里。

Set:即一组 Drive的集合,分布式部署根据集群规模自动划分一个或者多个Set,每个Set中的Drive 分布在不同位置。一个对象存储在一个Set上。

环境部署

服务端下载地址:https://dl.min.io/server/minio/release/

版本更新日志:https://github.com/minio/minio/releases

mc是客户端,提供了类似 unix 的命令去操作服务端,从https://dl.min.io/client/mc/release/按需下载

首先下载minio服务端,进入上面的地址,根据系统版本按需选择需要下载的服务端,minio是linux需要的,minio.exe是windows需要的。

服务搭建的方式有以下三种,本文只说前两种。

  • 单节点单驱动器

  • 单节点多驱动器

  • 多节点多驱动器(分布式)

Linux搭建

这里展示单节点单驱动器的做法,然后部署成systemctl管理的服务。

先创建目录minio-server

mkdir minio-server

将下好的minio文件放进去,

进入目录创建run.bat文件

vim run.sh

写入启动minio命令

#!/bin/bash
#设置登录账号和密码,控制台登录和api调用都是同一个
export MINIO_ROOT_USER=admin
#密码最短9位
export MINIO_ROOT_PASSWORD=930926134
#命令启动,这里是在后台运行,9001是api对应端口,9000是控制台页面对应端口,host是127.0.0.1,日志输出在当前目录下minio.log,数据是保存当前目录的data目录下
nohup ./minio server
--address ":9001"
--console-address ":9000"
./data >./minio.log 2>&1 & \

增加可执行权限

chmod +x run.sh

到这里可以先 ./run.sh 运行试试看,是否正常启动

启动后输出日志和创建了data目录

部署成服务,先创建minio.service

cd /etc/systemd/system/
vim minio.service

写入相关设置参数

[Unit]
Description=Minio service
Documentation=https://docs.minio.io/

[Service]
Type=forking
WorkingDirectory=/root/application/minio-2022-11-18/
ExecStart=/root/application/minio-2022-11-18/run.sh
ExecStop=/bin/kill -s QUIT $MAINPID
Restart=on-failure
RestartSec=5

[Install]
WantedBy=multi-user.target

[Unit]
Description=minio server
Documentation=minio
After=network.target remote-fs.target nss-lookup.target

刷新配置

systemctl daemon-reload

然后就可以通过systemctl来管理minio了

Windows搭建

这里展示单节点多驱动器的做法,先在minio.exe所在目录创建startMinio.bat文件,写入以下内容,和linux的启动命令差不多,这里指定了两个目录作为两个驱动器

set MINIO_ROOT_USER=admin
set MINIO_ROOT_PASSWORD=123456789
minio.exe server --console-address :9090 --address :9000 D:/minioData/data1 D:/minioData/data2

双击bat脚本启动后会打印一些日志,窗口不能关闭,相当于这就是服务了

现在本地浏览器访问 http://127.0.0.1:9090 输入账号密码即可进入控制台界面,控制台的操作可以自行研究,因为是可视化界面操作,比较简单,就不过多描述了。

具体使用

这里以java为例,包括后续都使用java作为开发语言。

minio的使用还是比较简单的,先导入minio的客户端依赖

// maven
<dependency>
    <groupId>io.minio</groupId>
    <artifactId>minio</artifactId>
    <version>8.4.6</version>
</dependency>

// gradle
implementation 'io.minio:minio:8.4.6'

然后如下创建一个连接minio服务的客户端实例就可以开始操作了

import io.minio.*;

public class FileUploader {
  public static void main(String[] args) {
    try {
      // 创建客户端
      MinioClient minioClient =
          MinioClient.builder()
        // api地址
              .endpoint("http://127.0.0.1:9000")
        // 前面设置的账号密码
              .credentials("admin", "123456789")
              .build();

      // 检查桶是否存在
      boolean found =
          minioClient.bucketExists(BucketExistsArgs.builder().bucket("testdir").build());
      if (!found) {
        // 创建桶
        minioClient.makeBucket(MakeBucketArgs.builder().bucket("testdir").build());
      }

      System.out.println("开始你的操作");
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
}

这里只举例了验证桶存在与否和创建桶的方法,桶就相当于文件夹,其他方法可以参考官方API文档:https://min.io/docs/minio/linux/developers/java/API.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值