Releases: mongodb/mongo-rust-driver
v2.7.0
The MongoDB Rust driver team is pleased to announce the v2.7.0 release of the mongodb
crate, now available for download from crates.io.
The Rust driver documentation is now hosted at https://www.mongodb.com/docs/drivers/rust/current/. This documentation includes detailed content about features, runnable examples, troubleshooting resources, and more.
Highlighted Changes
Serialization Behavior Change
When serializing values via serde, the serializer can indicate whether or not the target format is human-readable, allowing types to change behavior based on that. The Rust driver had inadvertently been serializing values given to find_one_and_replace
and replace_one
as human-readible when all other methods serialize as non-human-readible; this bug is fixed in 2.7.0, with those methods also serializing as non-human-readible.
However, it is potentially possible (if unlikely) that user code may rely on this bug. If your code does rely on human-readable serialization, you can specify that via the new human_readable_serialization
field in CollectionOptions
.
run_cursor_command
The Rust driver provides the run_command
method as a way for users to directly send bson commands to the server; this is particularly useful when the driver does not yet have support for a newly-added server command. However, using this with commands that return a cursor requires re-implementing the logic for cursor iteration, which can be tedious and error-prone. The new run_cursor_command
method avoids those problems, directly returning a Cursor
using the same iteration logic as other methods.
SDAM Logging
The Rust driver will now log SDAM events when using the tracing-unstable
feature.
Client Management
The Client
type now provides three additional ways to shape behavior to fit your workload:
ClientOptions.max_connecting
lets you specify how many "in flight" connections can be established in parallel. This was previously fixed at 2 and defaults to the same value.Client::warm_connection_pool
will create new connections to bring the connection pool up tomin_pool_size
, which can provide more predictable performance in some circumstances.Client::shutdown
will cleanly stop background tasks and wait for outstanding handles to be dropped. This is particularly useful when using event handlers that reference external resources, as otherwise those handlers may be invoked in a background task even after theClient
has been dropped.
Included Changes
Below are a selected list of changes with user impact; for a full list of changes see this GitHub query.
New Features
- RUST-1420 Cache AWS credentials received from endpoints (#905)
- RUST-1604 Add custom bucketing fields to timeseries options (#907)
- RUST-1588: Add RunCursorCommand (#912)
- RUST-802 Support Unix Domain Sockets (#908) (thanks @PureWhiteWu!)
- RUST-1509 SDAM Logging (#918)
- RUST-1608 Clean shutdown for Client (#920)
- RUST-1712 Provide a connection pool warmup method (#932)
- RUST-1712 Support User Configuration for max_connecting (#923) (thanks @LuisOsta!)
- RUST-1687 Add human_readable_serialization option to Collection (#902) (thanks @maiconpavi!)
Improvements
- RUST-1433 Propagate original error for some labeled retry errors (#903)
- minor: improve README.md (#934)
- upgrade webpki (#935) (thanks @fuchsnj!)
- RUST-1763 deprecate CollectionOptions::human_readable_serialization (#957) (#959)
Bugfixes
- Force non-human readable serialization in collections (#919) (#924) (thanks @kodemartin!)
- RUST-1699 / RUST-1718 AWS authentication fixes (#926)
- RUST-1719 Fix panic after SessionCursor::with_type is called (#928) (thanks @mlokr!)
- RUST-1743 Fix gridfs numeric type serialization (#941)
- RUST-1757 Fix final cursor batch handling (#951) (#954)
- fixing the find or delete serde inconsistency (#948) (#955) (thanks @mlokr!)
- minor: pin async-executor (#964) (#965)
v2.7.0-beta.1
The MongoDB Rust driver team is pleased to announce the v2.7.0-beta.1 release of the mongodb
crate, now available for download from crates.io.
Included Changes
Improvements
Bugfixes
v2.7.0-beta
The MongoDB Rust driver team is pleased to announce the v2.7.0-beta release of the mongodb
crate, now available for download from crates.io.
Highlighted Changes
BETA: Serialization Behavior Change
When serializing values via serde, the serializer can indicate whether or not the target format is human-readable, allowing types to change behavior based on that. The Rust driver had inadvertently been serializing values given to find_one_and_replace
and replace_one
as human-readible when all other methods serialize as non-human-readible; this bug is fixed in 2.7.0-beta, with those methods also serializing as non-human-readible.
However, it is potentially possible (if unlikely) that user code may rely on this bug, so out of an abundance of caution we are releasing this version as a beta. If your code does rely on human-readable serialization, you can specify that via the new human_readable_serialization
field in CollectionOptions
.
run_cursor_command
The Rust driver provides the run_command
method as a way for users to directly send bson commands to the server; this is particularly useful when the driver does not yet have support for a newly-added server command. However, using this with commands that return a cursor requires re-implementing the logic for cursor iteration, which can be tedious and error-prone. The new run_cursor_command
method avoids those problems, directly returning a Cursor
using the same iteration logic as other methods.
SDAM Logging
The Rust driver will now log SDAM events when using the tracing-unstable
feature.
Client Management
The Client
type now provides three additional ways to shape behavior to fit your workload:
ClientOptions.max_connecting
lets you specify how many "in flight" connections can be established in parallel. This was previously fixed at 2 and defaults to the same value.Client::warm_connection_pool
will create new connections to bring the connection pool up tomin_pool_size
, which can provide more predictable performance in some circumstances.Client::shutdown
will cleanly stop background tasks and wait for outstanding handles to be dropped. This is particularly useful when using event handlers that reference external resources, as otherwise those handlers may be invoked in a background task even after theClient
has been dropped.
Included Changes
Below are a selected list of changes with user impact; for a full list of changes see this GitHub query.
New Features
- RUST-1420 Cache AWS credentials received from endpoints (#905)
- RUST-1604 Add custom bucketing fields to timeseries options (#907)
- RUST-1588: Add RunCursorCommand (#912)
- RUST-802 Support Unix Domain Sockets (#908) (thanks @PureWhiteWu!)
- RUST-1509 SDAM Logging (#918)
- RUST-1608 Clean shutdown for Client (#920)
- RUST-1712 Provide a connection pool warmup method (#932)
- RUST-1712 Support User Configuration for max_connecting (#923) (thanks @LuisOsta!)
- RUST-1687 Add human_readable_serialization option to Collection (#902) (thanks @maiconpavi!)
Improvements
- RUST-1433 Propagate original error for some labeled retry errors (#903)
- minor: improve README.md (#934)
- upgrade webpki (#935) (thanks @fuchsnj!)
Bugfixes
v2.6.1
The MongoDB Rust driver team is pleased to announce the v2.6.1 release of the mongodb
crate, now available for download from crates.io. This release removes a potential panic from the SessionCursor::with_type
method.
Included Changes
Bugfixes
v2.6.0
The MongoDB Rust driver team is pleased to announce the v2.6.0 release of the mongodb
crate, now available for download from crates.io.
Included Changes
Below are a selected list of changes with user impact; for a full list of changes see this GitHub query.
New Features
- RUST-1421 Implement
FromStr
forNamespace
(#889) - RUST-906 Add native support for AWS IAM Roles for service accounts, EKS in particular (#885)
- RUST-1417 Add support for GCP attached service accounts when using GCP KMS (#877)
- RUST-1442 On-demand Azure KMS credentials (#872)
- RUST-1571 Add i64 server ID field to
ConnectionInfo
(#894)
Improvements
Bugfixes
- RUST-1645 Fix AWS Lambda detection logic (#876)
- RUST-1370 Only check specific fields for hello equality (#892)
Tasks
v2.5.0
The MongoDB Rust driver team is pleased to announce the v2.5.0 release of the mongodb
crate, now available for download from crates.io.
Highlighted Changes
In-Use Encryption: Automatically Create Keys
This release adds the ClientEncryption::create_encrypted_collection
helper method, which will automatically create encryption keys as needed when creating a collection with the encrypted_fields
option.
Convenient Transactions
This release adds the ClientSession::with_transaction
helper method, which will handle automatically creating, retrying, and committing or aborting a transaction.
Included Changes
Below are a selected list of changes with user impact; for a full list of changes see this GitHub query.
New Features
- RUST-1587 Implement server selection tracing events (#805)
- RUST-1314 Support on-demand AWS credentials for in-use encryption (#831)
- RUST-107 Convenient transactions (#849)
- RUST-1411 Add create_encrypted_collection helper (#853)
Improvements
- RUST-1069 Defer implicit session check out until after connection check out (#811)
- RUST-1582 Expose collection.client() as public (#822) (Thanks LuisOsta!)
- RUST-1503 Test csfle against older server versions (#832)
- RUST-1607: allow uuidRepresentation in connection string (#838) (Thanks terakilobyte!)
- RUST-1501 Collect FaaS platform metadata (#844)
- RUST-1585 Do not perform server selection to determine sessions support (#854)
Bugfixes
v2.4.0
The MongoDB Rust driver team is pleased to announce the v2.4.0 release of the mongodb
crate, now available for download from crates.io.
Highlighted Changes
In-Use Encryption
This release brings support for Client-Side Field Level Encryption and Queryable Encryption. For detailed installation and usage instructions, please see the Encryption section of the driver manual. Please note that the API is currently unstable and may change in breaking ways in future releases.
GridFS
This release adds support for GridFS, allowing storage and retrieval of files that exceed the BSON document size limit. Please see the documentation of the new gridfs module for more information.
Streaming Monitoring Protocol
This release can now use the streaming monitoring protocol with MongoDB 4.4+ servers, reducing the time it takes for the client to discover server state changes compared to the old polling protocol.
Tracing Integration
The driver now emits tracing
events at points of interest. To consume these events, you must enable the driver’s tracing-unstable
feature flag and either:
- register a tracing
Subscriber
in your application (see the tracing docs), OR - register a
log
-compatible logger in your application (see thelog
documentation for details), and enable alog
compatibility feature flag fortracing
, as detailed here.
This API is considered unstable as the tracing
crate has not reached 1.0 yet; future minor versions of the driver may upgrade the tracing
dependency to a new version which is not backwards-compatible with Subscriber
s that depend on older versions of tracing
.
Events will be emitted under the following targets:
mongodb::command
: Events related to command execution starting, succeeding, or failing.mongodb::connection
: Events related to the driver’s underlying connection pools and their connections.
Future work will introduce events under additional targets and may add driver-defined tracing spans for intervals of interest.
MSRV Increase
The minimum supported Rust version (MSRV) for this crate is now Rust 1.57.
Included Changes
Below are a selected list of changes with user impact; for a full list of changes see this GitHub query.
New Features
- RUST-1384 Implement auto encryption (#717)
- RUST-1385 Implement explicit encryption (#726)
- RUST-1305 Use uuid 1.x internally and add support for bson uuid 1.x (#709)
- RUST-1400 GridFS download methods (#747)
- RUST-1478 GridFS upload methods (#751)
- RUST-1401 Additional GridFS API (#763)
- RUST-580 Add tracing integration and command tracing events (#757)
- RUST-1510 Implement connection pool tracing messages (#766)
Improvements
- RUST-360 Streaming monitoring protocol (#721)
- RUST-1071 Add comment field to all options structs
- minor: improve compile error when sync and tokio-runtime features are enabled (#788)
- extend error types to impl serialization (#797) (Thanks borngraced!)
Bugfixes
- RUST-1443 Ensure monitors close after server is removed from topology (#744)
- RUST-1576 Allow "timeseries"-typed collections in list_collections output (#814)
- minor: fix documentation of new features (#823)
Tasks
- RUST-1253 Add AWS Lambda Examples (#714)
- Deps: bump dependencies (#722) (Thanks Some-Dood!)
- RUST-1445 Bump MSRV to 1.57 (#727)
- RUST-1403 Remove oldtime feature from chrono dependency (#691) (Thanks oskgo!)
- RUST-1450 Bump pretty_assertions dependency to 1.3.0 (#734)
- Fix typo in README (#735) (Thanks sgasse!)
- minor: document cursor/change stream Drop implementations (#745)
- RUST-1560 Fix README typo (#798) (Thanks lonesometraveler!)
v2.4.0-beta.2
The MongoDB Rust driver team is pleased to announce the v2.4.0-beta.2 release of the mongodb
crate, now available for download from crates.io. Please note that this is a beta release; the API for in-use encryption may change between this and the final 2.4.0 release.
Highlighted Changes
This release fixes a bug that caused the documentation for in-use encryption not to render on docs.rs.
v2.4.0-beta.1
The MongoDB Rust driver team is pleased to announce the v2.4.0-beta.1 release of the mongodb
crate, now available for download from crates.io. Please note that this is a beta release; the API for in-use encryption may change between this and the final 2.4.0 release.
Highlighted Changes
This release fixes a bug that could cause list_collections
to fail when timeseries collections were present; see RUST-1576 for details.
v2.4.0-beta
The MongoDB Rust driver team is pleased to announce the v2.4.0-beta release of the mongodb
crate, now available for download from crates.io. Please note that this is a beta release; the API for in-use encryption may change between this and the final 2.4.0 release.
Highlighted Changes
In-Use Encryption
This release brings support for Client-Side Field Level Encryption and Queryable Encryption. For detailed installation and usage instructions, please see the Encryption section of the driver manual. Please note that rewrapManyDataKey
and automatic KMS credentials are not yet supported in the Rust driver.
GridFS
This release adds support for GridFS, allowing storage and retrieval of files that exceed the BSON document size limit. Please see the documentation of the new gridfs module for more information.
Streaming Monitoring Protocol
This release can now use the streaming monitoring protocol with MongoDB 4.4+ servers, reducing the time it takes for the client to discover server state changes compared to the old polling protocol.
Tracing Integration
The driver now emits tracing
events at points of interest. To consume these events, you must enable the driver’s tracing-unstable
feature flag and either:
- register a tracing
Subscriber
in your application (see the tracing docs), OR - register a
log
-compatible logger in your application (see thelog
documentation for details), and enable alog
compatibility feature flag fortracing
, as detailed here.
This API is considered unstable as the tracing
crate has not reached 1.0 yet; future minor versions of the driver may upgrade the tracing
dependency to a new version which is not backwards-compatible with Subscriber
s that depend on older versions of tracing
.
Events will be emitted under the following targets:
mongodb::command
: Events related to command execution starting, succeeding, or failing.mongodb::connection
: Events related to the driver’s underlying connection pools and their connections.
Future work will introduce events under additional targets and may add driver-defined tracing spans for intervals of interest.
MSRV Increase
The minimum supported Rust version (MSRV) for this crate is now Rust 1.57.
Included Changes
Below are a selected list of changes with user impact; for a full list of changes see this GitHub query.
New Features
- RUST-1384 Implement auto encryption (#717)
- RUST-1385 Implement explicit encryption (#726)
- RUST-1305 Use uuid 1.x internally and add support for bson uuid 1.x (#709)
- RUST-1400 GridFS download methods (#747)
- RUST-1478 GridFS upload methods (#751)
- RUST-1401 Additional GridFS API (#763)
- RUST-580 Add tracing integration and command tracing events (#757)
- RUST-1510 Implement connection pool tracing messages (#766)
Improvements
- RUST-360 Streaming monitoring protocol (#721)
- RUST-1071 Add comment field to all options structs
- minor: improve compile error when sync and tokio-runtime features are enabled (#788)
- extend error types to impl serialization (#797) (Thanks borngraced!)
Bugfixes
Tasks
- RUST-1253 Add AWS Lambda Examples (#714)
- Deps: bump dependencies (#722) (Thanks Some-Dood!)
- RUST-1445 Bump MSRV to 1.57 (#727)
- RUST-1403 Remove oldtime feature from chrono dependency (#691) (Thanks oskgo!)
- RUST-1450 Bump pretty_assertions dependency to 1.3.0 (#734)
- Fix typo in README (#735) (Thanks sgasse!)
- minor: document cursor/change stream Drop implementations (#745)
- RUST-1560 Fix README typo (#798) (Thanks lonesometraveler!)