MINIO

MINIO服务器

minio 是一种简单的对象存储服务 教程:官网地址

  1. 利用docker起一个mini服务
docker run -p 9000:9000 --name minio \
-e "MINIO_ACCESS_KEY=TEST" \
-e "MINIO_SECRET_KEY=TEST123456" \
-v /mnt/data:/data \
-v /mnt/config:/root/.minio \
minio/minio server /data 

指定参数说明:MINIO_ACCESS_KEY MINIO_SECRET_KEY 是指定登陆客户端需要输入的
-v 是docker的持久化存储,会在本地建文件来存储数据,因为docker container删除后数据会消失
其中前面的指的是本地的路径:后面是容器对象的路径

然后在浏览器输入地址 会出现minio的管理界面。
在这里插入图片描述

minio常用sdk

初始化客户端

this.minioClient = new Minio.Client({
      ...this.options,
      endPoint: 'xxx.xxx.xxx.xxx',
      port: 9000,
      useSSL: false,
      accessKey: 'xxx',
      secretKey: 'xxxx',
    });

makeBucket

新建bucket

this.minioClient.makeBucket(BucketName, 'us-east-1', err => {
        if (err) {
          reject(err);
        } else {
          resolve('success');
        }
      });

bucketExists

判断bucket是否存在

this.minioClient.bucketExists(BucketName)

putObject

上传文件

const metaData = {
      'Content-Type': type,
    };
   this.minioClient.putObject(
        BucketName,
        fileName,
        file,
        1024,
        metaData,
      );

getObject

获取上传的文件流

this.minioClient.getObject(BucketName, fileName)

removeObject

删除文件

this.minioClient.removeObject(BucketName, fileName)
06-19
### MinIO 对象存储的设置与使用 MinIO 是一个高性能的对象存储系统,兼容 Amazon S3 API,广泛应用于存储非结构化数据,如照片、视频、日志文件等[^1]。以下是关于 MinIO 的设置和使用方法的详细说明。 #### 1. 单机部署 MinIO 的单机部署非常简单,适用于开发环境或小型生产环境。以下是具体步骤: - **下载 MinIO** 首先从官方提供的 URL 下载 MinIO 可执行文件。例如,在 CentOS 7 系统中,可以使用以下命令下载适合 x86_64 架构的二进制文件[^2]: ```bash wget https://dl.min.io/server/minio/release/linux-amd64/minio ``` - **赋予可执行权限** 下载完成后,为 `minio` 文件添加可执行权限: ```bash chmod +x minio ``` - **启动 MinIO** 使用以下命令启动 MinIO 服务,并指定存储路径和访问密钥: ```bash ./minio server /data --console-address ":9001" ``` 其中,`/data` 是存储对象数据的目录,`--console-address ":9001"` 指定了管理控制台的端口。 #### 2. 集群部署 MinIO 支持分布式集群模式,适用于高可用性和大规模存储需求的场景。集群部署通常需要配置 YAML 文件来定义节点信息。然而,某些 YAML 文件可能导致无法访问管理页面的问题[^4]。以下是一个简单的集群部署示例: - **编辑 YAML 文件** 创建一个 `minio.yaml` 文件,内容如下: ```yaml apiVersion: v1 kind: Service metadata: name: minio-service spec: type: NodePort ports: - port: 9000 targetPort: 9000 nodePort: 30001 protocol: TCP name: http - port: 9001 targetPort: 9001 nodePort: 30002 protocol: TCP name: console selector: app: minio --- apiVersion: apps/v1 kind: StatefulSet metadata: name: minio spec: serviceName: "minio-service" replicas: 4 selector: matchLabels: app: minio template: metadata: labels: app: minio spec: containers: - name: minio image: minio/minio args: - server - http://minio-0.minio-service.default.svc.cluster.local/data - http://minio-1.minio-service.default.svc.cluster.local/data - http://minio-2.minio-service.default.svc.cluster.local/data - http://minio-3.minio-service.default.svc.cluster.local/data env: - name: MINIO_ROOT_USER value: "minioadmin" - name: MINIO_ROOT_PASSWORD value: "minioadmin" ports: - containerPort: 9000 - containerPort: 9001 volumeMounts: - name: data mountPath: /data volumes: - name: data persistentVolumeClaim: claimName: minio-pvc ``` #### 3. 使用 MinIO 客户端 (mc) MinIO 提供了一个命令行工具 `mc`,用于管理 MinIO 服务器和操作对象数据。以下是几个常用命令: - **安装 mc** 在 Linux 系统中,可以通过以下命令安装 `mc`: ```bash wget https://dl.min.io/client/mc/release/linux-amd64/mc chmod +x mc sudo mv mc /usr/local/bin/ ``` - **配置 MinIO 服务器** 使用以下命令将 MinIO 服务器添加到 `mc` 配置中: ```bash mc alias set myminio http://localhost:9000 minioadmin minioadmin ``` - **列出桶** 列出所有存储桶: ```bash mc ls myminio ``` - **上传文件** 将本地文件上传到存储桶: ```bash mc cp localfile.txt myminio/mybucket/ ``` #### 4. 存储类型与优化 MinIO 提供了多种存储类型,用户可以根据需求选择合适的存储方案[^3]。例如,标准存储适合频繁访问的数据,而低频存储则适用于较少访问的数据。 --- ###
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值