minio/docs/zh_CN/compression/README.md

92 lines
3.4 KiB
Markdown
Raw Normal View History

# 压缩指南 [![Slack](https://slack.min.io/slack?type=svg)](https://slack.min.io)
MinIO Server 允许压缩流以确保有效使用磁盘空间。压缩是在传输中做的也就是说对象在写入磁盘之前已被压缩。MinIO使用 [`klauspost/compress/s2`](https://github.com/klauspost/compress/tree/master/s2) 进行流压缩,因为它高效稳定。
该算法专门针对机器生成的内容进行了优化。每个CPU核心的写入吞吐量至少为300MB/s。 解压缩速度通常至少为1GB/s。
这意味着在原始IO低于这些数字的情况下压缩不仅会减少磁盘使用量而且有助于提高系统吞吐量。
通常,当内容可以压缩时,在机械硬盘系统上启用压缩将提高速度。
## 开始使用
### 1. 前置条件
安装MinIO - [MinIO快速入门指南](https://docs.min.io/cn/minio-quickstart-guide).
### 2. 为MinIO启用压缩
可以通过更新MinIO Server配置的`compress`设置来启用压缩。`compress`设置可以配置哪些扩展名和mime-types可以被压缩。
```
$ mc admin config get myminio compression
compression extensions=".txt,.log,.csv,.json,.tar,.xml,.bin" mime_types="text/*,application/json,application/xml"
```
默认配置包括最常见的高度可压缩的内容扩展名和mime类型。
```
$ mc admin config set myminio compression extensions=".pdf" mime_types="application/pdf"
```
显示有关设置压缩配置的帮助。
```
~ mc admin config set myminio compression
```
使用默认的扩展名和mime-types对所有内容启用压缩。
```
~ mc admin config set myminio compression enable="on"
```
压缩设置也可以通过环境变量来设置。设置后,环境变量将覆盖服务器配置中定义的`compress`配置设置。
```bash
export MINIO_COMPRESS="on"
export MINIO_COMPRESS_EXTENSIONS=".pdf,.doc"
export MINIO_COMPRESS_MIME_TYPES="application/pdf"
```
### 3. 注意
- 已压缩的对象不具有可压缩的模式,因此不适合再压缩。 此类对象无法产生有效的 [`LZ 压缩`](https://en.wikipedia.org/wiki/LZ77_and_LZ78)。以下是不适合压缩的常见文件和内容类型列表。
- 扩展名
| `gz` | (GZIP)
| `bz2` | (BZIP2)
| `rar` | (WinRAR)
| `zip` | (ZIP)
| `7z` | (7-Zip)
| `xz` | (LZMA)
| `mp4` | (MP4)
| `mkv` | (MKV media)
| `mov` | (MOV)
- 内容类型
| `video/*` |
| `audio/*` |
| `application/zip` |
| `application/x-gzip` |
| `application/zip` |
| `application/x-bz2` |
| `application/x-compress` |
| `application/x-xz` |
即使所有类型都启用了压缩具有以上这些扩展名和mime类型的文件也不会被压缩。
- MinIO不支持压缩加密因为压缩和加密一起可能为[`CRIME 和 BREACH`](https://blog.minio.io/c-e-compression-encryption-cb6b7f04a369)等信道攻击留出空间。
- MinIO不支持网关Azure/GCS/NAS压缩。
## 测试设置
要测试设置, 使用`mc`PUT一个文件到服务器然后在数据目录上使用 `mc ls`查看对象的大小。
## 进一步探索
- [使用`mc`](https://docs.min.io/cn/minio-client-quickstart-guide)
- [使用`aws-cli`](https://docs.min.io/cn/aws-cli-with-minio)
- [使用`s3cmd`](https://docs.min.io/cn/s3cmd-with-minio)
- [使用`minio-go`](https://docs.min.io/cn/golang-client-quickstart-guide)
- [MinIO官方文档](https://docs.min.io/cn)