MinIO对象存储服务使用详解及实例演示

1,072 阅读2分钟

引言: 在现代的云计算环境中,对象存储服务已经成为了不可或缺的一部分。本文将详细介绍开源的对象存储服务 MinIO 的使用,并通过一个实例来演示如何搭建和使用 MinIO 进行文件的存储和管理。

image.png 一、MinIO简介 MinIO 是一个高性能、开源的对象存储服务器,兼容 Amazon S3 API。它提供了简单易用的命令行工具和丰富的 SDK,可以方便地在各种环境中使用。MinIO 具有高可用性、可扩展性和安全性,适用于大规模的数据存储需求。

二、安装 MinIO

  1. 下载 MinIO Server 首先,我们需要从 MinIO 的官方网站(min.io/download)下载… MinIO Server 二进制文件。

  2. 解压缩并启动 MinIO Server 解压缩下载的 MinIO Server 二进制文件,并在命令行中进入解压后的目录。然后执行以下命令启动 MinIO Server:

$ ./minio server /data

其中,/data 是用于存储数据的目录路径,可以根据需要自行修改。

三、配置 MinIO Server

  1. 设置访问密钥和秘密密钥 启动 MinIO Server 后,我们需要设置访问密钥和秘密密钥。可以通过以下命令获取访问密钥和秘密密钥:
$ cat ~/.minio/credentials.accesskey
$ cat ~/.minio/credentials.secretkey

确保将这两个密钥保存在一个安全的地方,以便后续使用。

  1. 配置访问权限 MinIO Server 默认情况下只允许本地访问。为了允许远程访问,我们需要进行一些配置。打开 ~/.minio/config 文件,添加以下内容:
[http]
address = ":9000"

这将启用 HTTP 访问端口为 9000。如果需要使用其他端口,请相应地修改该值。保存并关闭文件。

四、使用 MinIO Client 工具

  1. 安装 MinIO Client 工具 MinIO Client 工具是一个命令行工具,用于管理 MinIO Server。可以从 MinIO 的官方网站(min.io/download)下载… MinIO Client 二进制文件,并进行安装。

  2. 连接到 MinIO Server 使用以下命令连接到运行中的 MinIO Server:

$ minio client <endpoint>/<access-key>:<secret-key> /data

其中,<endpoint> 是 MinIO Server 的访问地址,例如 http://localhost:9000<access-key><secret-key> 分别是之前设置的访问密钥和秘密密钥;/data 是用于存储数据的目录路径。

  1. 列出存储桶列表 连接成功后,可以使用以下命令列出所有的存储桶(bucket):
$ ls my-bucket-name/

其中,my-bucket-name 是要列出存储桶名称的占位符,可以替换为实际的存储桶名称。

  1. 创建存储桶 使用以下命令创建一个名为 my-bucket 的新存储桶:
$ mkdir my-bucket/test-folder/subfolder/file.txt

这将在 my-bucket 存储桶下创建一个名为 test-folder 的文件夹,并在其中创建一个名为 subfolder 的子文件夹,最后在该子文件夹中创建一个名为 file.txt 的文件。可以根据需要修改文件夹和文件的名称和路径。

  1. 上传文件到存储桶 使用以下命令将本地文件上传到指定的存储桶中:
$ put local-file.txt my-bucket/test-folder/subfolder/file.txt

其中,local-file.txt 是要上传的本地文件路径,my-bucket/test-folder/subfolder/file.txt 是要上传到的目标路径。可以根据需要修改文件的路径和名称。

  1. 下载文件从存储桶中 使用以下命令从指定的存储桶中下载文件到本地:
$ get my-bucket/test-folder/subfolder/file.txt local-file.txt

其中,my-bucket/test-folder/subfolder/file.txt 是要下载的文件路径,local-file.txt 是要保存到本地的目标路径。可以根据需要修改文件的路径和名称。

  1. 删除存储桶或文件 使用以下命令删除指定的存储桶或文件:
$ remove my-bucket/test-folder/subfolder/file.txt # 删除文件
$ remove my-bucket # 删除整个存储桶及其所有内容和子文件夹等结构信息,但不会删除存储桶本身。要彻底删除存储桶及其所有内容,请使用 'rb'(remove bucket)选项。例如:$ remove --rb my-bucket # 删除整个存储桶及其所有内容和子文件夹等结构信息以及存储桶本身。