Skip to content

Commit

Permalink
PSMDB-1487 Release notes 8.0 (#936)
Browse files Browse the repository at this point in the history
* PSMDB-1487 Release notes 8.0

new file:   docs/release_notes/8.0.0-1.md
	modified:   docs/release_notes/index.md
	modified:   mkdocs-base.yml
	modified:   variables.yml



---------

Co-authored-by: Sandra Romanchenko <[email protected]>
  • Loading branch information
nastena1606 and sandraromanchenko authored Dec 17, 2024
1 parent 1b61376 commit 71263b4
Show file tree
Hide file tree
Showing 7 changed files with 157 additions and 6 deletions.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,5 @@ __pycache__
# Local Netlify folder
.netlify
site/
.cache/plugin/git-committers/page-authors.json
.cache/

40 changes: 40 additions & 0 deletions _resource/overrides/.icons/percona/logo-mongodb.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
106 changes: 106 additions & 0 deletions docs/release_notes/8.0.4-1.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@
# Percona Server for MongoDB 8.0.4-1 ({{date.8_0_4}})

[Installation](../install/index.md){.md-button}
[Upgrade](../install/upgrade-from-70.md){.md-button}

We are pleased to announce the new major version of Percona Server for MongoDB 8.0.4-1 – the drop in replacement for MongoDB Community Edition. Percona Server for MongoDB supports MongoDB Community protocols and drivers and enhances it with the [enterprise-grade features for free](../comparison.md), enabling you to effectively meet the requirements of your organization in terms of high-availability, reliability and data security.

This release of Percona Server for MongoDB includes the improvements and bug fixes of [MongoDB 8.0.0 Community Edition](https://www.mongodb.com/docs/manual/release-notes/8.0/#8.0.0---oct-2--2024) through [MongoDB 8.0.4 Community Edition](https://www.mongodb.com/docs/manual/release-notes/8.0/#8.0.4---dec-9--2024).

## Upgrade considerations

Starting with version 8.0, Percona Server for MongoDB uses the upgraded TCMalloc to handle memory requests more efficiently. The use of TCMalloc requires you to enable Transparent Huge Pages (THP) and per-CPU caches before you start Percona Server for MongoDB. In MongoDB 8.0 and later, ensure that THP is enabled before mongod starts by creating a service file for your platform's initialization system. If you are using MongoDB 7.0 or earlier - disable THP.

Read more about TCMalloc in [MongoDB documentation :octicons-link-external-16:](https://www.mongodb.com/docs/manual/administration/tcmalloc-performance/).


## Release Highlights

In addition to the [upstream improvements](#upstream-improvements), Percona Server for MongoDB features the following improvements:

### Prevent master encryption key loss on the Vault server

Before Percona Server for MongoDB puts a new master encryption key to the Vault server as the versioned secret, it now checks if the secret's version reached the defined maximum (10 by default). This prevents the loss of the old secret and the master encryption key it stores on the Vault server.

Make sure Percona Server for MongoDB has read permissions for the secret's metadata and the secrets engine configuration. To learn more, refer to the [documentation](../vault.md#master-key-loss-prevention).

### Join Percona Squad

Participate in monthly SWAG raffles, get an early access to new product features and invite-only "ask me anything" sessions with database performance experts. Interested? Fill in the form at [squad.percona.com/mongodb](squad.percona.com/mongodb).

### Upstream Improvements

MongoDB 8.0 introduces a lot of major changes. We recommend testing it on staging environments before using it in production. The features and improvements in MongoDB 8.0 are focused on the following main areas:

#### Performance improvements

* Benefit from faster performance when working with time series collections. A new algorithm enhances time series speed by processing queries in "blocks" of data rather than individual values.
* Insert operations for multi-document transactions no longer produce single oplog entries. Instead, they are now batched as a single entry. This change increases multi-document insert performance and improves replication efficiency, reducing lag.
* Oplog buffers for replication are now introduced. A new writer thread reads new entries from the primary and writes them to the local oplog on each secondary. An independent applier thread asynchronously applies changes to the local database, increasing replication throughput.
* The upgraded TCMalloc version is now the default in MongoDB. Together with THP and per-CPU cache, it reduces memory fragmentation by 18% which is especially useful during peak loads.

#### Workload management

Analyze query performance and manage the workload in your system using [query shapes](https://www.mongodb.com/docs/manual/core/query-shapes/#std-label-query-shapes). A query shape is a set of specifications to group similar queries together. For a query shape, you add query settings instead of index filters. Query settings are persistent meaning that they remain after the cluster restart thus saving you from rerunning them in your application. A query shape has the `queryShapeHash` parameter using which you can check if the operation causes excessive workload and deny it using operation rejection filters.

#### Developer experience

* Insert, update or delete multiple collections in one request with the new [`bulkWrite`](https://www.mongodb.com/docs/manual/reference/command/bulkWrite/#mongodb-dbcommand-dbcmd.bulkWrite) command. Previously you could only run these operations on a single collection.
* Several enhancements are made to the index build process such as a better error handling and tolerance to disk space issues. This avoids common secondary crashes due to errors.


#### Sharding improvements

* To better optimize resources or distribute the data more evenly across the shards, you can now [move a single unsharded collection to any shard](https://www.mongodb.com/docs/manual/core/moveable-collections/#std-label-moveable-collections) with the new `moveCollection` command. This operation is going online and the collection data is fully available during the migration. This new way to move data is flexible and the read and write behavior when you query data is transparent.
* Ensuring even data distribution across shards in your cluster is crucial. Starting with MongoDB 5.0, you can reshard a collection using a different shard key, although this operation is time-consuming. In MongoDB 8.0, you can reshard a collection using the same shard key, significantly boosting performance. This is especially beneficial for large collections, reducing resharding time from days to several hours. You can dynamically reallocate your resources based on the workload. The process is online, so your operations run uninterrupted. The ability to add or remove shards without changing the shard key makes the whole resharding process straightforward.
* You can now [unshard a collection](https://www.mongodb.com/docs/manual/tutorial/unshard-collection/#std-label-unshard-collection-task) if it should reside on a single shard or the collection requires resource isolation. You can either specify the desired shard or the collection will be moved onto the shard with the least load.
* You can now save costs on additional computing resources when deploying a sharded cluster. The config server replica set can now store both the configuration and the database data. Such a deployment is recommended for small clusters and is especially useful for evaluating the cluster without having to pay extra costs.
* You can now make self-managed backups in sharded clusters using `mongodump`. Run the [`fsync`](https://www.mongodb.com/docs/manual/reference/command/fsync/#mongodb-dbcommand-dbcmd.fsync) command with the `lock` field set to `true` from `mongos` to lock each shard and prevent further writes. Then, run `fsynckUnlock` to unlock shards. Note that this process blocks all database writes while the fsync is in place.

#### Logging improvements

You can now configure database profiler to log slow operations based on the time MongoDB actually spent processing that operation. This gives you more accuracy when you analyze performance.

#### Security improvements

* You can now run range queries on encrypted fields, specifically for numeric data types and dates. This expands the range of use cases for Manual Queryable Encryption, including accounting operations, healthcare, financial services, and other strictly regulated data operations where data safety is crucial.

Other improvements include the following:

* [SERVER-73641](https://jira.mongodb.org/browse/SERVER-73641) - Fix the issue with timeseries filtering missing extended-range events when sharded
* [SERVER-82037](https://jira.mongodb.org/browse/SERVER-82037) - Fixed the issue with extreme memory usage by sorter by limiting the number of file iterators a sorter can create
* [SERVER-94559](https://jira.mongodb.org/browse/SERVER-94559) - Fixed the issue with tracking the archived bucket based on the minTime in the bucket registry for time series measurements by leaving the bucket's minTime unchanged when performing user deletes/updates on it
* [SERVER-95067](https://jira.mongodb.org/browse/SERVER-95067) - Handle multiple batches per bucket in time-series insert
* [SERVER-95724](https://jira.mongodb.org/browse/SERVER-95724) - Make resharding unroll multiple applyOps when it clones the retryable write session info to a recipient
* [SERVER-93205](https://jira.mongodb.org/browse/SERVER-93205) - Enabled the `indexStats` section of the `serverStatus` command output to track indexes in the `prepareUnique` state.
* [SERVER-92762](https://jira.mongodb.org/browse/SERVER-92762) - Improved the resilience and performance of sharding in the cluster by setting the default value of `numInitialChunks` in `reshardCollection` to 90.
* [SERVER-91777](https://jira.mongodb.org/browse/SERVER-91777) - Disabled oplog sampling during restore procedure to optimize the restore time
* [SERVER-90965](https://jira.mongodb.org/browse/SERVER-90965) - Extended query settings to include optional comment field. This may be helpful to persist details about a change for audit or easier troubleshooting. Read more in https://www.mongodb.com/docs/manual/reference/command/setQuerySettings/
* [WT-13377](https://jira.mongodb.org/browse/WT-13377) - Reconfiguring a session with `cache_max_wait_ms` now accepts a value of zero
* [SERVER-94970](https://jira.mongodb.org/browse/SERVER-94970) - Fixed the issue with sharded `$searchMeta` queries in a `$lookup` and `$unionWith` failing by hitting an `unreachable_tassert`
* [SERVER-95240](https://jira.mongodb.org/browse/SERVER-95240) - Removed PeerID from SSL handshakes
* [SERVER-95067](https://jira.mongodb.org/browse/SERVER-95067) - Fixed the issue with time-series inserts generating multiple batches referencing the same bucket.
* [SERVER-84769](https://jira.mongodb.org/browse/SERVER-84769) - Changed the resharding remainingOpTime algorithm by adding initial delay to resharding commit monitor query
* [SERVER-67816](https://jira.mongodb.org/browse/SERVER-67816) - Fixed time rounding for timeseries control block of dates prior to 1970
* [SERVER-96419](https://jira.mongodb.org/browse/SERVER-96419) - Fixed the issue with improper neutralization of null bytes that may have led to buffer over-reads in MongoDB Server
* [SERVER-95279](https://jira.mongodb.org/browse/SERVER-95279) - Use a new C++ type for BSON field names to ensure validity
* [SERVER-76883](https://jira.mongodb.org/browse/SERVER-76883) - Suppressed the "role does not exist" warning log for LDAP group role resolution
* [SERVER-82221](https://jira.mongodb.org/browse/SERVER-82221) - Included commit-pending metadata entries to the listCollections and listIndexes output
* [SERVER-94635](https://jira.mongodb.org/browse/SERVER-94635) - Improved handling of logical session refresh by making the session refresh parameters configurable
* [SERVER-95244](https://jira.mongodb.org/browse/SERVER-95244) - Fixed the `tassert()` failure for upsert operations run when a client connects directly to shard
* [WT-13409](https://jira.mongodb.org/browse/WT-13409) - Fixed the data corruption issue by properly handling a return value from a function call in transaction checkpoint in WiredTiger

Find the full list of changes in the [MongoDB 8.0.4 Community Edition release notes](https://www.mongodb.com/docs/manual/release-notes/8.0/#8.0.4---dec-9--2024).

## Changelog

### Improvements

* [PSMDB-1441](https://perconadev.atlassian.net/browse/PSMDB-1441) - Fixed the issue with master encryption keys getting lost when the number of created secrets exceeds the threshold by preventing a new secret creation and alerting users about it.

### Fixed Bugs

* [PSMDB-1527](https://perconadev.atlassian.net/browse/PSMDB-1527) - Improve the activateKeys option handling by changing its type to boolean.



2 changes: 2 additions & 0 deletions docs/release_notes/index.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@

# Percona Server for MongoDB 8.0 release notes

* [Percona Server for MongoDB 8.0.4-1 ({{date.8_0_4}})](8.0.4-1.md)

7 changes: 4 additions & 3 deletions mkdocs-base.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ theme:
content.action.edit
content.code.copy
content.copy.annotate
content.tooltips
search.highlight
search.share
search.suggest
Expand Down Expand Up @@ -144,7 +145,7 @@ plugins:
with-pdf: # https://github.com/orzih/mkdocs-with-pdf
output_path: '_pdf/PerconaServerforMongoDB-8.0.pdf'
cover_title: 'Server for MongoDB Documentation 8.0'
cover_subtitle:
cover_subtitle: 8.0.4-1 (December 17, 2024)
author: 'Percona Technical Documentation Team'
cover_logo: docs/_images/Percona_Logo_Color.png
debug_html: false
Expand Down Expand Up @@ -215,11 +216,11 @@ nav:
- install/uninstall.md
- Release notes:
- "Release notes index": "release_notes/index.md"
- release_notes/7.0.2-1.md
- release_notes/8.0.4-1.md
- faq.md
- Reference:
- glossary.md
- telemetry.md
- copyright.md
- trademark-policy.md

- Join Percona Squad: "https://squad.percona.com/mongodb"
2 changes: 1 addition & 1 deletion snippets/services-banner.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,6 @@ If you need assistance, visit the community forum for comprehensive and free dat

<div class="actions" markdown>

[:material-forum-outline: Community Forum](https://forums.percona.com/c/mongodb/percona-server-for-mongodb/43) [:percona-logo: Get a Percona Expert](https://www.percona.com/about/contact)
[:material-forum-outline: Community Forum](https://forums.percona.com/c/mongodb/percona-server-for-mongodb/43) [:percona-logo: Get a Percona Expert](https://www.percona.com/about/contact) [:percona-logo-mongodb: Join Percona Squad](https://squad.percona.com/mongodb)

</div></div>
3 changes: 2 additions & 1 deletion variables.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,5 @@ version: '8.0'
mongosh: '2.3.2'

date:
8_0_4 : "2024-12-11"
8_0_4 : "2024-12-17"

0 comments on commit 71263b4

Please sign in to comment.