Overview
在本指南中,您可以了解如何使用 Rust 驱动程序为与 MongoDB 的连接配置网络压缩。
网络压缩功能允许您压缩和解压缩应用程序与 MongoDB 之间发送的消息,从而减少通过网络传递的数据总量。
该驱动程序支持以下压缩程序:
注意
压缩器选择
如果您指定在连接上使用多个压缩器,驱动程序会选择其连接的 MongoDB 实例支持的第一个压缩器。
本指南包括以下部分:
添加压缩功能标志
要使用压缩器,请将相关功能标志添加到项目Cargo.toml文件中mongodb依赖项的功能列表中。
选择首选压缩程序的标签页,查看如何将必要的功能标志添加到mongodb依赖项中:
[dependencies.mongodb] version = "3.1.1" features = ["snappy-compression"] 
[dependencies.mongodb] version = "3.1.1" features = ["zlib-compression"] 
[dependencies.mongodb] version = "3.1.1" features = ["zstd-compression"] 
提示
要指定多个压缩程序,必须将每个压缩程序的功能标志添加到mongodb依赖项中。
启用网络压缩
您可以通过以下方式指定压缩程序,在Client实例上启用压缩:
- 将 - compressors参数添加到连接string中。 要查看以这种方式启用压缩的示例,请参阅连接string部分。
- 设置 - ClientOptions实例的- compressors字段。 然后,您可以在实例化- Client时将选项传递给- with_options()方法。 要查看以这种方式启用压缩的示例,请参阅ClientOptions部分。
连接字符串
要使用连接字符串启用压缩,请指定compressors参数。 您可以为compressors参数指定以下一个或多个值:
- "snappy"用于 Snappy 压缩
- "zlib",用于 Zlib 压缩
- "zstd"用于 Zstandard 压缩
以下示例显示如何将 Snappy、Zlib 和 Zstandard 指定为连接的压缩程序:
let uri = "mongodb+srv://<db_username>:<db_password>@<cluster-url>/?compressors=snappy,zlib,zstd"; let client = Client::with_uri_str(uri).await?; 
要学习;了解有关设置客户端选项的详情,请参阅连接选项指南。
ClientOptions
要在ClientOptions实例中启用压缩,请设置compressors字段,然后在创建客户端时传递选项。
compressors字段采用Vec<Compressor>类型的值。 Compressor类型具有以下可能的值:
- Compressor::Snappy
- Compressor::Zstd { level: <integer> }
- Compressor::Zlib { level: <integer> }
对于具有level字段的压缩器,将该值设置为None以指示默认级别。 下表描述了 Zlib 和 Zstandard 的默认和可接受的压缩级别:
| Compressor | 默认级别 | 已接受级别 | 
|---|---|---|
| zlib | 
 | 从 | 
| Zstandard | 
 | 从 | 
level值越高,压缩程度越高,速度越慢。
以下示例显示如何将 Snappy、Zlib 和 Zstandard 指定为连接的压缩程序:
let uri = "<connection string>"; let mut client_options = ClientOptions::parse(uri).await?; let compressors = vec![     Compressor::Snappy,     Compressor::Zstd { level: Some(1) },     Compressor::Zlib { level: None } ]; client_options.compressors = Some(compressors); let client = Client::with_options(client_options)?; 
更多信息
有关本指南中概念的更多信息,请参阅以下文档:
- 手册中的 string连接 压缩选项MongoDB Server 
API 文档
要进一步了解本指南所提及的任何方法或类型,请参阅以下 API 文档: