MinIO 存储类型快速入门 Slack

在纠删码模式下,MinIO server支持存储类型. 这可以指定每个对象的数据和奇偶校验盘,其实就是可以为对象选择不同的存储类型.

概述

MinIO 支持两种存储类型, 低冗余存储和标准存储。 这些存储类型可以在MinIO服务器启动之前通过环境变量定义。 在通过环境变量定义了每个存储类型的数据和奇偶校验盘的数量后, 你可以通过请求中的元数据字段x-amz-storage-class来设置一个对象的存储类型。然后MinIO服务器通过将对象保存在特定数量的数据和奇偶校验盘中来兑现存储类型。

可用存储空间

选择不同的数据和奇偶校验盘的数量会直接影响到存储空间的使用。通过存储类型,你能优化以实现高冗余或者是更好的空间利用率。

让我们以在16个盘的MinIO部署中存储100M文件为例来了解数据和奇偶校验盘数量的不同组合是如何影响可用存储空间的。如果你使用8个数据盘和8个奇偶校验盘文件空间使用量约为两倍 即100M文件将占用200M空间。但是如果你是用10个数据盘和6个奇偶校验盘则同样的100M文件大约需要160M的空间。如果你是用14个数据盘和2个奇偶校验盘100M文件仅仅需要约114M空间。

以下是一张16盘的MinIO部署数据/奇偶校验盘数量和相应的 近似 存储储空间使用情况列表。空间使用率 约等于纠删编码下的使用空间除以文件的实际大小。

盘总个数 (N) 数据盘个数 (D) 奇偶校验码个数 (P) 空间使用率
16 8 8 2.00
16 9 7 1.79
16 10 6 1.60
16 11 5 1.45
16 12 4 1.34
16 13 3 1.23
16 14 2 1.14

你可以使用公式: 盘总个数 (N)/数据盘个数 (D)来计算 大概的 空间使用率。

标准(STANDARD)存储类型的允许值

STANDARD存储类型意味着奇偶校验盘比REDUCED_REDUNDANCY多。 所以, STANDARD的奇偶校验盘数量应该

  • 如果REDUCED_REDUNDANCY的奇偶校验盘未设置的话应该大于等于2。
  • 如果已设置的话,应该大于REDUCED_REDUNDANCY的奇偶校验盘数量。

奇偶校验块不能大于数据块,所以STANDARD存储类型的奇偶校验块不能大于N/2。N是盘总个数

STANDARD存储类型的默认值是N/2N是盘总个数

低冗余(REDUCED_REDUNDANCY)存储类型的允许值

REDUCED_REDUNDANCY存储类型意味着奇偶校验盘比REDUCED_REDUNDANCY少。 所以, REDUCED_REDUNDANCY的奇偶校验盘数量应该

  • 如果STANDARD的奇偶校验盘未设置的话应该小于2。
  • 如果设置的话,应该小于STANDARD的奇偶校验盘数量。

因为不建议奇偶校验盘数量低于2 所以4个盘组成的纠删码模式部署是不支持REDUCED_REDUNDANCY存储类型的。

REDUCED_REDUNDANCY存储类型的默认值是2

存储类型入门

设置存储类型

设置存储类型环境变量的格式如下

MINIO_STORAGE_CLASS_STANDARD=EC:parity MINIO_STORAGE_CLASS_RRS=EC:parity

例如, 设置 MINIO_STORAGE_CLASS_RRS 奇偶校验盘为2 以及设置 MINIO_STORAGE_CLASS_STANDARD 奇偶校验盘为3

export MINIO_STORAGE_CLASS_STANDARD=EC:3
export MINIO_STORAGE_CLASS_RRS=EC:2

也可以通过mc admin config get/set 命令来设置存储类型。参考 存储类型 获取更多详细信息。

注意

  • 如果通过环境变量或mc admin config get/set命令设置了STANDARD存储类型,并且请求元数据中不存在x-amz-storage-class则MinIO服务器会将STANDARD存储类型应用于该对象。这意味着将按照STANDARD存储类型中的设置使用数据和奇偶校验盘数量。

  • 如果在启动MinIO服务器之前未定义存储类型并且随后的PutObject元数据字段中存在x-amz-storage-class,其值为REDUCED_REDUNDANCYSTANDARD则MinIO服务器将使用默认的奇偶校验值。

设置元数据

如下minio-go的示例中,存储类型被设置为REDUCED_REDUNDANCY。这意味着对象被拆分为6个数据块和2个奇偶校验块(按照上一步骤中的存储类型设置)。

s3Client, err := minio.New("localhost:9000", "YOUR-ACCESSKEYID", "YOUR-SECRETACCESSKEY", true)
if err != nil {
	log.Fatalln(err)
}

object, err := os.Open("my-testfile")
if err != nil {
	log.Fatalln(err)
}
defer object.Close()
objectStat, err := object.Stat()
if err != nil {
	log.Fatalln(err)
}

n, err := s3Client.PutObject("my-bucketname", "my-objectname", object, objectStat.Size(), minio.PutObjectOptions{ContentType: "application/octet-stream", StorageClass: "REDUCED_REDUNDANCY"})
if err != nil {
	log.Fatalln(err)
}
log.Println("Uploaded", "my-objectname", " of size: ", n, "Successfully.")