RabbitMQ 4.0.8
is a maintenance release in the 4.0.x
release series.
Starting June 1st, 2024, community support for this series will only be provided to regularly contributing users and those
who hold a valid commercial support license.
It is strongly recommended that you read 4.0 release notes
in detail if upgrading from a version prior to 4.0.0
.
Minimum Supported Erlang Version
This release requires Erlang 26 and supports Erlang versions up to 27.3.x
.
RabbitMQ and Erlang/OTP Compatibility Matrix has more details on
Erlang version requirements for RabbitMQ.
Nodes will fail to start on older Erlang releases.
Changes Worth Mentioning
Release notes can be found on GitHub at rabbitmq-server/release-notes.
Core Broker
Bug Fixes
-
Fixes a number of rare replication safety issues for quorum queues and Khepri.
GitHub issue: #13530
-
Peer discovery retry limit supports the value of
infinity
but thecluster_formation.discovery_retry_limit
key inrabbitmq.conf
only accepted positive integers.Contributed by @SimonUnge.
GitHub issue: #13676
Enhancements
-
Quorum queue checkpoint algorithm was tweaked to take checkpoints more frequently, thus
clearing older segment files more aggressively.Workloads that use larger messages should continue following the documented recommendations to
avoid large disk space footprint of segment files.GitHub issue: #13622
-
Previously a node that was a cluster member but then was reset could not
rejoin the cluster if the schema data store was Mnesia.Now the reset node will try to leave the cluster and retry rejoining again.
This was already the case for Khepri.Contributed by @SimonUnge.
GitHub issue: #13669
CLI Tools
Enhancements
-
rabbitmqadmin
2.0.0 GA is now available as a standalone binary.Learn more:
rabbitmq/rabbitmqadmin-ng
-
New health check commands help detect quorum queues without an elected leader.
# Verifies that all quorum queues in virtual host "vh-1" match the naming pattern "^naming-pattern" # have an elected leader rabbitmq-diagnostics check_for_quorum_queues_without_an_elected_leader --vhost "vh-1" "^naming-pattern" # Verifies that all quorum queues in the cluster have an elected leader. This can be an expensive # operation if there are many quorum queues in the cluster, consider providing a more specific pattern rabbitmq-diagnostics check_for_quorum_queues_without_an_elected_leader --across-all-vhosts ".*"
Contributed by @Ayanda-D.
GitHub issue: #13489
Stream Plugin
Bug Fixes
-
When a connection of one or more consumers in a Single Active Consumer group failed,
the group could try to activate (promote) one of the consumers are are no longer online. In practical terms
this means that other consumers were not getting any deliveries.GitHub issue: #13660
-
TCP load balancer health checks (TCP connections that do not proceed to complete the RabbitMQ Stream Protocol handshake)
previously resulted in an exception in the log.GitHub issue: #13678
Enhancements
-
Stream replication connections now can be configured to use IPv6 using
advanced.config
:[ {osiris, [ {replica_ip_address_family, inet6} ]} ].
Management Plugin
Bug Fixes
-
If HTTP API was configured to use a custom prefix, OAuth 2-based authentication would fail
because one of the cookies used by the workflow was using an absolute path.GitHub issue: #13668
-
Several endpoints could produce an exception when the requested resource (queue or exchange) did not exist.
GitHub issue: #13619
-
When OAuth 2 was enabled with an IDP-initiated login,
the UI displayed a confusing warning.GitHub issue: #13507
Enhancements
-
Historically, HTTP API access was controlled by exactly the same authentication and authorization backend chain
that were configured for the messaging protocol connections.Now it is possible to use a separate chain, that is, a separate set of backends, specifically for the HTTP API access:
# Messaging protocol access auth_backends.1 = ldap auth_backends.2 = internal # HTTP API access http_dispatch.auth_backends.1 = http
Contributed by @aaron-seo.
GitHub issue: #13467
-
A new
rabbitmq.conf
setting,management.delegate_count
, controls the size of the pool of processes
that aggregate data to respond to HTTP API client requests.The default value is
5
. Nodes that have access to a double digit numbers of CPU cores (say, 32)
could benefit from using a higher number, e.g.10
or16
.Contributed by @Ayanda-D.
GitHub issue: #13462
Shovel Plugin
Bug Fixes
-
AMQP 1.0 shovels could stop consuming after
2^16 - 1
messages.GitHub issue: #13578
LDAP Plugin
Enhancements
-
The
in_group_nested
query now uses case-insensitive matching, which is more typical of the LDAP tooling.GitHub issue: #13633
Dependency Changes
Source Code Archives
To obtain source code of the entire distribution, please download the archive named rabbitmq-server-4.0.8.tar.xz
instead of the source tarball produced by GitHub.