Skip to content

Releases: rabbitmq/rabbitmq-server

RabbitMQ 4.0.8

03 Apr 05:11
7a7eb55
Compare
Choose a tag to compare

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 the cluster_formation.discovery_retry_limit key in rabbitmq.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 or 16.

    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

  • ra was upgraded to 2.15.3
  • osiris was updated to 1.8.6
  • credentials_obfuscation was upgraded to 3.5.0

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.

RabbitMQ 4.1.0-rc.1

02 Apr 02:17
6363ca0
Compare
Choose a tag to compare
RabbitMQ 4.1.0-rc.1 Pre-release
Pre-release

RabbitMQ 4.1.0-rc.1 is a candidate of a new feature release.

See Compatibility Notes below to learn about breaking or potentially breaking changes in this release.

Highlights

Some key improvements in this release are listed below.

Quorum Queue Throughput and Parallelism Improvements

Quorum queue log reads are now offloaded to channels (sessions, connections).

In practical terms this means improved consumer throughput, lower interference of publishers
on queue delivery rate to consumers, and improved CPU core utilization by each quorum queue
(assuming there are enough cores available to the node).

Initial Support for AMQP 1.0 Filter Expressions

Support for the properties and appliation-properties filters of AMQP Filter Expressions Version 1.0 Working Draft 09.

Feature Flags Quality of Life Improvements

Graduated (mandatory) feature flags several minors ago has proven that they could use some user experience improvements.
For example, certain required feature flags will now be enabled on node boot when all nodes in the cluster support them.

See core server changes below as well as the GitHub project dedicated to feature flags improvements
for the complete list of related changes.

Breaking Changes and Compatibility Notes

Initial AMQP 0-9-1 Maximum Frame Size

Before a client connection can negotiate a maximum frame size (frame_max), it must authenticate
successfully. Before the authenticated phase, a special lower frame_max value
is used.

With this release, the value was increased from the original 4096 bytes to 8192
to accommodate larger JWT tokens.

Clients that do override frame_max now must use values of 8192 bytes or greater.
We recommend using the default server value of 131072: do not override the frame_max
key in rabbitmq.conf and do not set it in the application code.

amqplib is a popular client library that has been using
a low frame_max default of 4096. Its users must upgrade to a compatible version
(starting with 0.10.7) or explicitly use a higher frame_max.

MQTT

  • The default MQTT Maximum Packet Size changed from 256 MiB to 16 MiB.

    This default can be overridden by configuring mqtt.max_packet_size_authenticated.
    Note that this value must not be greater than max_message_size (which also defaults to 16 MiB).

etcd Peer Discovery

The following rabbitmq.conf settings are unsupported:

  • cluster_formation.etcd.ssl_options.fail_if_no_peer_cert
  • cluster_formation.etcd.ssl_options.dh
  • cluster_formation.etcd.ssl_options.dhfile

Erlang/OTP Compatibility Notes

This release requires Erlang 26.2 and supports Erlang 27.x.

Provisioning Latest Erlang Releases explains
what package repositories and tools can be used to provision latest patch versions of Erlang 26.x and 27.x.

Release Artifacts

Artifacts for preview releases are distributed via GitHub releases:

There is a 4.1.0 preview version of the community RabbitMQ image.

Upgrading to 4.1.0

Documentation guides on upgrades

See the Upgrading guide for documentation on upgrades and GitHub releases
for release notes of individual releases.

This release series supports upgrades from 4.0.x and 3.13.x.

Blue/Green Deployment-style upgrades are avaialble for migrations
from RabbitMQ 3.12.x series.

Required Feature Flags

None/TBD.

Mixed version cluster compatibility

RabbitMQ 4.1.0 nodes can run alongside 4.0.x nodes. 4.1.x-specific features can only be made available when all nodes in the cluster
upgrade to 4.0.0 or a later patch release in the new series.

While operating in mixed version mode, some aspects of the system may not behave as expected. The list of known behavior changes will be covered in future updates.
Once all nodes are upgraded to 4.1.0, these irregularities will go away.

Mixed version clusters are a mechanism that allows rolling upgrade and are not meant to be run for extended
periods of time (no more than a few hours).

Recommended Post-upgrade Procedures

This version does not require any additional post-upgrade procedures
compared to other versions.

Changes Worth Mentioning

This section can be incomplete and will be expanded as 4.1 approaches its release candidate stage.

Core Server

Enhancements

  • Quorum queue log reads are now offloaded to channels (sessions, connections).

    In practical terms this means improved consumer throughput, lower interference of publishers
    on queue delivery rate to consumers, and improved CPU core utilization by each quorum queue
    (assuming there are enough cores available to the node).

    GitHub issue: #12713

  • Feature flag quality of live improvements.

    Certain required feature flags will now be automatically required on node boot
    and do not have to be explicitly enabled before an upgrade.
    This does not apply to all feature flags, however.

    GitHub project: #4.

    GitHub issues: #12466, #12444,
    #12447

  • properties and appliation-properties filters of AMQP Filter Expressions Version 1.0 Working Draft 09
    when consuming from a stream via AMQP 1.0. String prefix and suffix matching is also supported.

    This feature adds the ability to RabbitMQ to have multiple concurrent clients each consuming only a subset of messages while maintaining message order.
    It also reduces network traffic between RabbitMQ and clients by only dispatching those messages that the clients are actually interested in.

    GitHub issue: #12415

  • Larger (up to 8192 bytes) JWT tokens now can be used by AMQP 0-9-1 clients.

    Before a client connection can negotiate a maximum frame size (frame_max), it must authenticate
    successfully. Before the authenticated phase, a special lower frame_max value
    is used.

    Clients that do override frame_max now must use values of 8192 bytes or greater.
    We recommend using the default server value of 131072: do not override the frame_max
    key in rabbitmq.conf and do not set it in the application code.

    amqplib is a popular client library that has been using
    a low frame_max default of 4096. Its users must upgrade to a compatible version
    (starting with 0.10.7) or explicitly use a higher frame_max.

    GitHub issue: #13541

  • AMQP 1.0 connections that use OAuth 2.0 now can renew their JWT tokens
    This allows clients to set a new token proactively before the current one expires, ensuring uninterrupted connectivity.
    If a client does not set a new token before the existing one expires, RabbitMQ will automatically close the AMQP 1.0 connection.

    GitHub issue: #12599

  • AMQP 1.0 filters now have capped complexity: filtering on more than 16 properties
    won't be possible. This is a protection mechanism recommended in the AMQP 1.0 spec.

    GitHub issue: #13196

  • Support for Multiple Routing Keys in AMQP 1.0 via x-cc Message Annotation.

    AMQP 1.0 publishers now can set multiple routing keys by using the x-cc message annotation.
    This annotation allows publishers to specify a list
    of routing keys (strings) for more flexible message distribution,
    similar to the CC header in AMQP 0.9.1.

    GitHub issue: #12559

  • Support field dynamic of AMQP 1.0 source and target.

    This allows AMQP clients to dynamically create exclusive queues, which can be useful for RPC workloads.

    GitHub issue: #13231

  • Quorum queue checkpoint algorithm was tw...

Read more

RabbitMQ 4.1.0-beta.5

20 Mar 03:57
ef5162e
Compare
Choose a tag to compare
RabbitMQ 4.1.0-beta.5 Pre-release
Pre-release

RabbitMQ 4.1.0-beta.5 is a preview release (in development) of a new feature release.

See Compatibility Notes below to learn about breaking or potentially breaking changes in this release.

Highlights

Some key improvements in this release are listed below.

Initial Support for AMQP 1.0 Filter Expressions

Support for the properties and appliation-properties filters of AMQP Filter Expressions Version 1.0 Working Draft 09.

Feature Flags Quality of Life Improvements

Graduated (mandatory) feature flags several minors ago has proven that they could use some user experience improvements.
For example, certain required feature flags will now be enabled on node boot when all nodes in the cluster support them.

See core server changes below as well as the GitHub project dedicated to feature flags improvements
for the complete list of related changes.

Breaking Changes and Compatibility Notes

Initial AMQP 0-9-1 Maximum Frame Size

Before a client connection can negotiate a maximum frame size (frame_max), it must authenticate
successfully. Before the authenticated phase, a special lower frame_max value
is used.

With this release, the value was increased from the original 4096 bytes to 8192
to accommodate larger JWT tokens.

Clients that do override frame_max now must use values of 8192 bytes or greater.
We recommend using the default server value of 131072: do not override the frame_max
key in rabbitmq.conf and do not set it in the application code.

MQTT

  • The default MQTT Maximum Packet Size changed from 256 MiB to 16 MiB.

    This default can be overridden by configuring mqtt.max_packet_size_authenticated.
    Note that this value must not be greater than max_message_size (which also defaults to 16 MiB).

etcd Peer Discovery

The following rabbitmq.conf settings are unsupported:

  • cluster_formation.etcd.ssl_options.fail_if_no_peer_cert
  • cluster_formation.etcd.ssl_options.dh
  • cluster_formation.etcd.ssl_options.dhfile

Erlang/OTP Compatibility Notes

This release requires Erlang 26.2 and supports Erlang 27.x.

Provisioning Latest Erlang Releases explains
what package repositories and tools can be used to provision latest patch versions of Erlang 26.x and 27.x.

Release Artifacts

Artifacts for preview releases are distributed via GitHub releases:

There is a 4.1.0 preview version of the community RabbitMQ image.

Upgrading to 4.1.0

Documentation guides on upgrades

See the Upgrading guide for documentation on upgrades and GitHub releases
for release notes of individual releases.

This release series only supports upgrades from 4.0.x.

Blue/Green Deployment-style upgrades are avaialble for migrations from 3.12.x and 3.13.x series
to 4.1.x.

Required Feature Flags

None/TBD.

Mixed version cluster compatibility

RabbitMQ 4.1.0 nodes can run alongside 4.0.x nodes. 4.1.x-specific features can only be made available when all nodes in the cluster
upgrade to 4.0.0 or a later patch release in the new series.

While operating in mixed version mode, some aspects of the system may not behave as expected. The list of known behavior changes will be covered in future updates.
Once all nodes are upgraded to 4.1.0, these irregularities will go away.

Mixed version clusters are a mechanism that allows rolling upgrade and are not meant to be run for extended
periods of time (no more than a few hours).

Recommended Post-upgrade Procedures

This version does not require any additional post-upgrade procedures
compared to other versions.

Changes Worth Mentioning

This section can be incomplete and will be expanded as 4.1 approaches its release candidate stage.

Core Server

Enhancements

  • Feature flag quality of live improvements.

    Certain required feature flags will now be automatically required on node boot
    and do not have to be explicitly enabled before an upgrade.
    This does not apply to all feature flags, however.

    GitHub project: #4.

    GitHub issues: #12466, #12444,
    #12447

  • properties and appliation-properties filters of AMQP Filter Expressions Version 1.0 Working Draft 09
    when consuming from a stream via AMQP 1.0. String prefix and suffix matching is also supported.

    This feature adds the ability to RabbitMQ to have multiple concurrent clients each consuming only a subset of messages while maintaining message order.
    It also reduces network traffic between RabbitMQ and clients by only dispatching those messages that the clients are actually interested in.

    GitHub issue: #12415

  • AMQP 1.0 connections that use OAuth 2.0 now can renew their JWT tokens
    This allows clients to set a new token proactively before the current one expires, ensuring uninterrupted connectivity.
    If a client does not set a new token before the existing one expires, RabbitMQ will automatically close the AMQP 1.0 connection.

    GitHub issue: #12599

  • AMQP 1.0 filters now have capped complexity: filtering on more than 16 properties
    won't be possible. This is a protection mechanism recommended in the AMQP 1.0 spec.

    GitHub issue: #13196

  • Support for Multiple Routing Keys in AMQP 1.0 via x-cc Message Annotation.

    AMQP 1.0 publishers now can set multiple routing keys by using the x-cc message annotation.
    This annotation allows publishers to specify a list
    of routing keys (strings) for more flexible message distribution,
    similar to the CC header in AMQP 0.9.1.

    GitHub issue: #12559

  • Support field dynamic of AMQP 1.0 source and target.

    This allows AMQP clients to dynamically create exclusive queues, which can be useful for RPC workloads.

    GitHub issue: #13231

  • Nodes will now fall back to system CA certificate list (if available) when no CA certificate
    is explicitly configured.

    Contributed by @LoisSotoLopez.

    GitHub issue: #10519, #12564

  • AMQP 1.0 and AMQP 0-9-1 connections now dynamically adjust their TCP socket buffers.

    GitHub issue: #13363

  • Peer discovery resilience improvements.

    GitHub issues: #12801, #12809

  • AMQP 1.0 and AMQP 0-9-1 connections now produce more specific error messages when an incorrect data is sent
    by the client during connection negotiation.

    For example, when a TLS-enabled client connects to a non-TLS port, or an HTTP GET request is sent to the AMQP port.

    GitHub issue: #13559

  • AMQP 0-9-1 and AMQP 1.0 connections now use a higher pre-authentication maximum allowed frame limit size by default.
    This means that larger JWT tokens can be accepted without any configuration.

    GitHub issue: #13542

  • Plugins now can mark queues and streams as protected from deletion by applications.

    GitHub issue: #13525

  • Internal API changes needed by a future version of the message deduplication plugin.

    Contributed by @noxdafox.

    GitHub issue: #13374

Bug Fixes

  • AMQP 0-9-1 channel exception generator could not handle entity names (say, queue or stream names)
    that contained non-ASCII characters.

    This affected applications that use passive...

Read more

RabbitMQ 4.0.7

26 Feb 19:07
cbb2037
Compare
Choose a tag to compare

RabbitMQ 4.0.7 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.2.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

  • Classic queue message store did not remove segment files with large messages (over 4 MB) in some cases.

    GitHub issue: #13430

  • A node with Khepri enabled would fail to start if its metadata store contained an exclusive queue
    with at least one binding.

    GitHub issues: #13352, #13394

Enhancements

  • Reduced memory usage and GC pressure for workloads where large (4 MB or greater) messages were published to classic queues.

    Contributed by @gomoripeti.

    GitHub issue: #13375

CLI Tools

Deprecations

  • rabbitmq-streams set_stream_retention_policy is now a no-op.

    It was a leftover from the early days of streams. The modern and optimal way of configuring
    stream retention is via a policy.

    GitHub issue: #13358

Prometheus Plugin

Enhancements

  • New labels make it possible to differentiate between the metrics with the same name scraped from the aggregated
    metric endpoint and the per-object metric endpoint.

    GitHub issue: #13239

Management Plugin

Bug Fixes

  • Two help tooltips were not updated for 4.0.x.

    GitHub issue: #13357

Enhancements

  • Consumer count is a new column that can be enabled for the channels table on the tab of the same name.

    Contributed by @gomoripeti.

    GitHub issue: #13258

Caching Authentication and Authorization Backend Plugin

Enhancements

Dependency Changes

Source Code Archives

To obtain source code of the entire distribution, please download the archive named rabbitmq-server-4.0.7.tar.xz
instead of the source tarball produced by GitHub.

RabbitMQ 4.0.6

11 Feb 18:29
6b1e03f
Compare
Choose a tag to compare

RabbitMQ 4.0.6 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.2.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

  • When a quorum queue leader has changed, followers were not always notified of
    unapplied [for/by them] log commands.

    GitHub issue: #13095

  • Default cluster formation timeout with Khepri now matches that of Mnesia (5 minutes by default).

    Discovered and reported by @evolvedlight.

    GitHub issue: #13195

  • When stream consumer was cancelled, an internal event was not emitted.

    GitHub issues: #13085, #9356, #13097

  • Stream consumer metrics were not cleared when its respective connection was closed.

    GitHub issue: #13086

  • Quorum queues could return a list of members (replicas) with duplicates in some cases.

    GitHub issue: #13168

  • Classic queues with priorities could run into an exception.

    GitHub issue: #13088

  • Corrected a log message.

    GitHub issue: #13155

Enhancements

CLI Tools

Bug Fixes

  • rabbitmqctl import_definitions hanged when definitions were provided via the standard input
    instead of a file.

    GitHub issue: #13157

Enhancements

  • rabbitmqadmin v2 has matured enough to recommend
    it over the original version of the tool

  • rabbitmq-diagnostics CLI documentation was improved to clarify that all certificates
    discovered will be checked for expiration.

    GitHub issue: #13038

  • New health checks for metadata store initialization:

    1. rabbitmq-diagnostics check_if_metadata_store_is_initialized
    2. rabbitmq-diagnostics check_if_metadata_store_is_initialized_with_data

    GitHub issue: #13169

Prometheus Plugin

Bug Fixes

  • Improved metric description.

    GitHub issue: #13178

Management Plugin

Bug Fixes

  • Pagination-related sections of the HTTP API reference were clarified to explain
    that the maximum page size cannot exceed 500.

    GitHub issue: #13042

  • Empty channel_details objects are now serialized as empty objects and not empty arrays.

    GitHub issue: #13091

Enhancements

  • New health checks for metadata store initialization:

    1. GET /api/health/checks/metadata-store/initialized
    2. GET /api/health/checks/metadata-store/initialized/with-data

    GitHub issue: #13169

Deprecations

  • The original HTTP API One True Health Check™ is now a no-op. A comparable "mega health check"
    has long been deprecated in CLI tools and was made a no-op in 4.0.0.

    This endpoint was using a deprecated feature: a classic non-exclusive transient (non-durable) queue.

    See Health Checks for modern focused alternatives.

    GitHub issue: #13047

Consul Peer Discovery Plugin

Enhancements

  • cluster_formation.registration.enabled is a new configuration setting that allows the backend to skip registration.

    This is useful when Consul is used for peer discovery but a different tool such as Nomad
    is used to keep track of the services and their registration, unregistration.

    Contributed by @frederikbosch.

    GitHub issue: #13201

Erlang AMQP 1.0 Client

Bug Fixes

  • Purging an non-existing queue now returns a 404 response.

    GitHub issue: #13148

Dependency Changes

  • ra was upgraded to 2.15.1
  • observer_cli was upgraded to 1.8.2

Source Code Archives

To obtain source code of the entire distribution, please download the archive named rabbitmq-server-4.0.6.tar.xz
instead of the source tarball produced by GitHub.

RabbitMQ 4.1.0-beta.4

10 Feb 15:45
a4f9bab
Compare
Choose a tag to compare
RabbitMQ 4.1.0-beta.4 Pre-release
Pre-release

RabbitMQ 4.1.0-beta.4 is a preview release (in development) of a new feature release.

See Compatibility Notes below to learn about breaking or potentially breaking changes in this release.

Highlights

Some key improvements in this release are listed below.

Initial Support for AMQP 1.0 Filter Expressions

Support for the properties and appliation-properties filters of AMQP Filter Expressions Version 1.0 Working Draft 09.

Feature Flags Quality of Life Improvements

Graduated (mandatory) feature flags several minors ago has proven that they could use some user experience improvements.
For example, certain required feature flags will now be enabled on node boot when all nodes in the cluster support them.

See core server changes below as well as the GitHub project dedicated to feature flags improvements
for the complete list of related changes.

Breaking Changes and Compatibility Notes

MQTT

  • The default MQTT Maximum Packet Size changed from 256 MiB to 16 MiB.

    This default can be overridden by configuring mqtt.max_packet_size_authenticated.
    Note that this value must not be greater than max_message_size (which also defaults to 16 MiB).

etcd Peer Discovery

The following rabbitmq.conf settings are unsupported:

  • cluster_formation.etcd.ssl_options.fail_if_no_peer_cert
  • cluster_formation.etcd.ssl_options.dh
  • cluster_formation.etcd.ssl_options.dhfile

Erlang/OTP Compatibility Notes

This release requires Erlang 26.2 and supports Erlang 27.x.

Provisioning Latest Erlang Releases explains
what package repositories and tools can be used to provision latest patch versions of Erlang 26.x and 27.x.

Release Artifacts

Artifacts for preview releases are distributed via GitHub releases:

There is a 4.1.0 preview version of the community RabbitMQ image.

Upgrading to 4.1.0

Documentation guides on upgrades

See the Upgrading guide for documentation on upgrades and GitHub releases
for release notes of individual releases.

This release series only supports upgrades from 4.0.x.

Blue/Green Deployment-style upgrades are avaialble for migrations from 3.12.x and 3.13.x series
to 4.1.x.

Required Feature Flags

None/TBD.

Mixed version cluster compatibility

RabbitMQ 4.1.0 nodes can run alongside 4.0.x nodes. 4.1.x-specific features can only be made available when all nodes in the cluster
upgrade to 4.0.0 or a later patch release in the new series.

While operating in mixed version mode, some aspects of the system may not behave as expected. The list of known behavior changes will be covered in future updates.
Once all nodes are upgraded to 4.1.0, these irregularities will go away.

Mixed version clusters are a mechanism that allows rolling upgrade and are not meant to be run for extended
periods of time (no more than a few hours).

Recommended Post-upgrade Procedures

This version does not require any additional post-upgrade procedures
compared to other versions.

Changes Worth Mentioning

This section can be incomplete and will be expanded as 4.1 approaches its release candidate stage.

Core Server

Enhancements

  • Feature flag quality of live improvements.

    Certain required feature flags will now be automatically required on node boot
    and do not have to be explicitly enabled before an upgrade.
    This does not apply to all feature flags, however.

    GitHub project: #4.

    GitHub issues: #12466, #12444,
    #12447

  • properties and appliation-properties filters of AMQP Filter Expressions Version 1.0 Working Draft 09
    when consuming from a stream via AMQP 1.0. String prefix and suffix matching is also supported.

    This feature adds the ability to RabbitMQ to have multiple concurrent clients each consuming only a subset of messages while maintaining message order.
    It also reduces network traffic between RabbitMQ and clients by only dispatching those messages that the clients are actually interested in.

    GitHub issue: #12415

  • AMQP 1.0 connections that use OAuth 2.0 now can renew their JWT tokens
    This allows clients to set a new token proactively before the current one expires, ensuring uninterrupted connectivity.
    If a client does not set a new token before the existing one expires, RabbitMQ will automatically close the AMQP 1.0 connection.

    GitHub issue: #12599

  • Nodes will now fall back to system CA certificate list (if available) when no CA certificate
    is explicitly configured.

    Contributed by @LoisSotoLopez.

    GitHub issue: #10519, #12564

  • AMQP 1.0 filters now have capped complexity: filtering on more than 16 properties
    won't be possible. This is a protection mechanism recommended in the AMQP 1.0 spec.

    GitHub issue: #13196

  • Support for Multiple Routing Keys in AMQP 1.0 via x-cc Message Annotation.

    AMQP 1.0 publishers now can set multiple routing keys by using the x-cc message annotation.
    This annotation allows publishers to specify a list
    of routing keys (strings) for more flexible message distribution,
    similar to the CC header in AMQP 0.9.1.

    GitHub issue: #12559

  • Peer discovery resilience improvements.

    GitHub issues: #12801, #12809

Bug Fixes

  • AMQP 0-9-1 channel exception generator could not handle entity names (say, queue or stream names)
    that contained non-ASCII characters.

    This affected applications that use passive queue declarations, such as the Shovel plugin.

    Contributed by @bpint.

    GitHub issue: #12888

  • Reintroduced transient flow control between classic queue replicas and AMQP 0-9-1 channels,
    MQTT connections.

    Flow control between these specific parts of the core were unintentionally
    removed in 4.0.0 together with classic queue mirroring.

    Contributed by @gomoripeti.

    GitHub issue: #12907

  • AMQP 1.0 connections with a higher consumption rate could set the incoming window field
    on the flow frame to a negative value, which resulted in an exception that affected the consumer.

    GitHub issues: #12816

  • In rare cases quorum queue could end up without an elected leader because
    chosen candidate replica was not verified for aliveness.

    Contributed by @Ayanda-D.

    GitHub issues: #12727, #10423, #12701

  • When a new replica is added to a quorum queue, the node that handles this request will now wait
    the operation to complete. Previously an early return could result in confusing cluster_change_not_permitted
    errors for subsequent operations, for example, an addition of another replica.

    GitHub issue: #12837

  • In a mixed version 4.0/3.13 cluster, dead lettering a message could fail.

    GitHub issue: #12933

  • In very rare cases, RabbitMQ could fail to notify stream consumers connected to follower replicas
    about newly committed offsets as quickly as it usually happens for consumers connected to the stream leader.

    GitHub issue: #12785

Bug Fixes

  • Default cluster formation timeout with Khepri now matches that of Mnesia (5 minutes by default).

    Discovered and reported by @evolvedlight.

    GitHub issue: #13195

  • Quorum queues could return a list of members (replicas) with duplicates in some cases.

    GitHub issue: [#13168](https://...

Read more

RabbitMQ 4.0.5

16 Dec 03:55
293a4f6
Compare
Choose a tag to compare

RabbitMQ 4.0.5 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.2.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

  • Reintroduced transient flow control between classic queue replicas and AMQP 0-9-1 channels,
    MQTT connections.

    Flow control between these specific parts of the core were unintentionally
    removed in 4.0.0 together with classic queue mirroring.

    Contributed by @gomoripeti.

    GitHub issue: #12907

  • The feature that warns when deprecated features are used in the cluster had a false positive that treated (and reported) any queue
    as a "transient non-exclusive classic queue", even if the queue was of a different type, was not transient, and so on.

    GitHub issue: #12802

  • AMQP 1.0 clients with close to peak consumption rates with a high max_link_creadit setting could run into an exception
    because RabbitMQ could set the incoming window size to a negative value.

    GitHub issues: #12816, #12904

  • AMQP 0-9-1 channel exception generator could not handle entity names (say, queue or stream names)
    that contained non-ASCII characters.

    This affected applications that use passive queue declarations, such as the Shovel plugin.

    Contributed by @bpint.

    GitHub issue: #12888

  • Peer discovery resilience improvements.

    GitHub issues: #12801, #12809

  • Deadlettering of some messages could result in an exception.

    GitHub issue: #12933, #12938

Enhancements

  • For virtual hosts that have a default queue type configured, the DQT value is now injected into
    queue definitions in exported definition documents.

    GitHub issue: #12776

  • Definition export files now have an additional "type" markers that help distinguish a cluster-wide definition file from
    that of a single virtual host.

    GitHub issue: #12835

Prometheus Plugin and Grafana Dashboards

Enhancements

Management Plugin

Bug Fixes

  • Fixes a false positive that incorrectly reported deprecated feature use, specifically
    the use of non-exclusive transient classic queues.

    GitHub issue: #12840

  • GET /api/overview did not format empty cluster and node list tags as an empty JSON object,
    which was problematic for HTTP API clients with statically typed response data structures.

    GitHub issue: #12797

  • When a logged in user's JWT token was refreshed, the user identity displayed in the UI was changed.

    GitHub issue: #12818

OAuth 2 Plugin

Bug Fixes

  • When a logged in user's JWT token was refreshed, the user identity displayed in the UI was changed.

    GitHub issue: #12818

AWS Peer Discovery Plugin

Bug Fixes

  • Avoids an exception during automatic removal of cluster members that are
    no longer returned by peer discovery (an opt-in feature).

    GitHub issue: #12809

Kubernetes Peer Discovery Plugin

Bug Fixes

  • Avoids an exception during automatic removal of cluster members that are
    no longer returned by peer discovery (an opt-in feature).

    GitHub issue: #12809

Consul Peer Discovery Plugin

Bug Fixes

  • Avoids an exception during automatic removal of cluster members that are
    no longer returned by peer discovery (an opt-in feature).

    GitHub issue: #12809

etcd Peer Discovery Plugin

Bug Fixes

  • Avoids an exception during automatic removal of cluster members that are
    no longer returned by peer discovery (an opt-in feature).

    GitHub issue: #12809

Dependency Changes

  • osiris was upgraded to 1.8.5

Build Commit

293a4f6

Source Code Archives

To obtain source code of the entire distribution, please download the archive named rabbitmq-server-4.0.5.tar.xz
instead of the source tarball produced by GitHub.

RabbitMQ 4.1.0-beta.3

11 Dec 01:15
dbd03d7
Compare
Choose a tag to compare
RabbitMQ 4.1.0-beta.3 Pre-release
Pre-release

RabbitMQ 4.1.0-beta.3 is a preview release (in development) of a new feature release.

See Compatibility Notes below to learn about breaking or potentially breaking changes in this release.

Highlights

Some key improvements in this release are listed below.

Initial Support for AMQP 1.0 Filter Expressions

Support for the properties and appliation-properties filters of AMQP Filter Expressions Version 1.0 Working Draft 09.

Feature Flags Quality of Life Improvements

Graduated (mandatory) feature flags several minors ago has proven that they could use some user experience improvements.
For example, certain required feature flags will now be enabled on node boot when all nodes in the cluster support them.

See core server changes below as well as the GitHub project dedicated to feature flags improvements
for the complete list of related changes.

Breaking Changes and Compatibility Notes

MQTT

  • The default MQTT Maximum Packet Size changed from 256 MiB to 16 MiB.

    This default can be overridden by configuring mqtt.max_packet_size_authenticated.
    Note that this value must not be greater than max_message_size (which also defaults to 16 MiB).

Erlang/OTP Compatibility Notes

This release requires Erlang 26.2 and supports Erlang 27.x.

Provisioning Latest Erlang Releases explains
what package repositories and tools can be used to provision latest patch versions of Erlang 26.x.

Release Artifacts

Artifacts for preview releases are distributed via GitHub releases:

There is a 4.1.0 preview version of the community RabbitMQ image.

Upgrading to 4.1.0

Documentation guides on upgrades

See the Upgrading guide for documentation on upgrades and GitHub releases
for release notes of individual releases.

This release series only supports upgrades from 4.0.x.

Blue/Green Deployment-style upgrades are avaialble for migrations from 3.12.x and 3.13.x series
to 4.1.x.

Required Feature Flags

None/TBD.

Mixed version cluster compatibility

RabbitMQ 4.1.0 nodes can run alongside 4.0.x nodes. 4.1.x-specific features can only be made available when all nodes in the cluster
upgrade to 4.0.0 or a later patch release in the new series.

While operating in mixed version mode, some aspects of the system may not behave as expected. The list of known behavior changes will be covered in future updates.
Once all nodes are upgraded to 4.1.0, these irregularities will go away.

Mixed version clusters are a mechanism that allows rolling upgrade and are not meant to be run for extended
periods of time (no more than a few hours).

Recommended Post-upgrade Procedures

This version does not require any additional post-upgrade procedures
compared to other versions.

Changes Worth Mentioning

This section can be incomplete and will be expanded as 4.1 approaches its release candidate stage.

Core Server

Enhancements

  • Feature flag quality of live improvements.

    Certain required feature flags will now be automatically required on node boot
    and do not have to be explicitly enabled before an upgrade.
    This does not apply to all feature flags, however.

    GitHub project: #4.

    GitHub issues: #12466, #12444,
    #12447

  • properties and appliation-properties filters of AMQP Filter Expressions Version 1.0 Working Draft 09
    when consuming from a stream via AMQP 1.0. String prefix and suffix matching is also supported.

    This feature adds the ability to RabbitMQ to have multiple concurrent clients each consuming only a subset of messages while maintaining message order.
    It also reduces network traffic between RabbitMQ and clients by only dispatching those messages that the clients are actually interested in.

    GitHub issue: #12415

  • AMQP 1.0 connections that use OAuth 2.0 now can renew their JWT tokens
    This allows clients to set a new token proactively before the current one expires, ensuring uninterrupted connectivity.
    If a client does not set a new token before the existing one expires, RabbitMQ will automatically close the AMQP 1.0 connection.

    GitHub issue: #12599

  • Nodes will now fall back to system CA certificate list (if available) when no CA certificate
    is explicitly configured.

    Contributed by @LoisSotoLopez.

    GitHub issue: #10519, #12564

  • Support for Multiple Routing Keys in AMQP 1.0 via x-cc Message Annotation.

    AMQP 1.0 publishers now can set multiple routing keys by using the x-cc message annotation.
    This annotation allows publishers to specify a list
    of routing keys (strings) for more flexible message distribution,
    similar to the CC header in AMQP 0.9.1.

    GitHub issue: #12559

  • Peer discovery resilience improvements.

    GitHub issues: #12801, #12809

Bug Fixes

  • AMQP 0-9-1 channel exception generator could not handle entity names (say, queue or stream names)
    that contained non-ASCII characters.

    This affected applications that use passive queue declarations, such as the Shovel plugin.

    Contributed by @bpint.

    GitHub issue: #12888

  • Reintroduced transient flow control between classic queue replicas and AMQP 0-9-1 channels,
    MQTT connections.

    Flow control between these specific parts of the core were unintentionally
    removed in 4.0.0 together with classic queue mirroring.

    Contributed by @gomoripeti.

    GitHub issue: #12907

  • AMQP 1.0 connections with a higher consumption rate could set the incoming window field
    on the flow frame to a negative value, which resulted in an exception that affected the consumer.

    GitHub issues: #12816

  • In rare cases quorum queue could end up without an elected leader because
    chosen candidate replica was not verified for aliveness.

    Contributed by @Ayanda-D.

    GitHub issues: #12727, #10423, #12701

  • When a new replica is added to a quorum queue, the node that handles this request will now wait
    the operation to complete. Previously an early return could result in confusing cluster_change_not_permitted
    errors for subsequent operations, for example, an addition of another replica.

    GitHub issue: #12837

  • In very rare cases, RabbitMQ could fail to notify stream consumers connected to follower replicas
    about newly committed offsets as quickly as it usually happens for consumers connected to the stream leader.

    GitHub issue: #12785

MQTT Plugin

Enhancements

  • The default MQTT Maximum Packet Size changed from 256 MiB to 16 MiB.

    This default can be overridden by configuring mqtt.max_packet_size_authenticated.
    Note that this value must not be greater than max_message_size (which also defaults to 16 MiB).

CLI Tools

Enhancements

  • New major version of rabbitmqadmin, a CLI tool that targets RabbitMQ's HTTP API, is maturing.
    Unlike its predecessor, the tool is distirbuted via GitHub as as a standalone native binary.

    There are minor command line interface changes and a slightly different configuration file
    format (TOML instead of ini)

    GitHub repository: rabbitmq/rabbitmqadmin-ng

  • rabbitmq-diagnostics check_if_any_deprecated_features_are_used implementation is now more complete
    (checks for a more deprecated features).

    GitHub ...

Read more

RabbitMQ 4.1.0-beta.2

23 Nov 23:37
10508c0
Compare
Choose a tag to compare
RabbitMQ 4.1.0-beta.2 Pre-release
Pre-release

RabbitMQ 4.1.0-beta.2 is a preview release (in development) of a new feature release.

See Compatibility Notes below to learn about breaking or potentially breaking changes in this release.

Highlights

Some key improvements in this release are listed below.

Initial Support for AMQP 1.0 Filter Expressions

Support for the properties and appliation-properties filters of AMQP Filter Expressions Version 1.0 Working Draft 09.

Feature Flags Quality of Life Improvements

Graduated (mandatory) feature flags several minors ago has proven that they could use some user experience improvements.
For example, certain required feature flags will now be enabled on node boot when all nodes in the cluster support them.

See core server changes below as well as the GitHub project dedicated to feature flags improvements
for the complete list of related changes.

Breaking Changes and Compatibility Notes

MQTT

  • The default MQTT Maximum Packet Size changed from 256 MiB to 16 MiB.

    This default can be overridden by configuring mqtt.max_packet_size_authenticated.
    Note that this value must not be greater than max_message_size (which also defaults to 16 MiB).

Erlang/OTP Compatibility Notes

This release requires Erlang 26.2.

Provisioning Latest Erlang Releases explains
what package repositories and tools can be used to provision latest patch versions of Erlang 26.x.

Release Artifacts

TBD

Upgrading to 4.1.0

Documentation guides on upgrades

See the Upgrading guide for documentation on upgrades and GitHub releases
for release notes of individual releases.

This release series only supports upgrades from 4.0.x.

Blue/Green Deployment-style upgrades are avaialble for migrations from 3.12.x and 3.13.x series
to 4.1.x.

Required Feature Flags

None/TBD.

Mixed version cluster compatibility

RabbitMQ 4.1.0 nodes can run alongside 4.0.x nodes. 4.1.x-specific features can only be made available when all nodes in the cluster
upgrade to 4.0.0 or a later patch release in the new series.

While operating in mixed version mode, some aspects of the system may not behave as expected. The list of known behavior changes will be covered in future updates.
Once all nodes are upgraded to 4.1.0, these irregularities will go away.

Mixed version clusters are a mechanism that allows rolling upgrade and are not meant to be run for extended
periods of time (no more than a few hours).

Recommended Post-upgrade Procedures

TBD

Changes Worth Mentioning

This section is incomplete and will be expanded as 4.1 approaches its release candidate stage.

Core Server

Enhancements

  • Feature flag quality of live improvements.

    Certain required feature flags will now be automatically required on node boot
    and do not have to be explicitly enabled before an upgrade.
    This does not apply to all feature flags, however.

    GitHub project: #4.

    GitHub issues: #12466, #12444,
    #12447

  • properties and appliation-properties filters of AMQP Filter Expressions Version 1.0 Working Draft 09
    when consuming from a stream via AMQP 1.0. String prefix and suffix matching is also supported.

    This feature adds the ability to RabbitMQ to have multiple concurrent clients each consuming only a subset of messages while maintaining message order.
    It also reduces network traffic between RabbitMQ and clients by only dispatching those messages that the clients are actually interested in.

    GitHub issue: #12415

  • AMQP 1.0 connections that use OAuth 2.0 now can renew their JWT tokens
    This allows clients to set a new token proactively before the current one expires, ensuring uninterrupted connectivity.
    If a client does not set a new token before the existing one expires, RabbitMQ will automatically close the AMQP 1.0 connection.

    GitHub issue: #12599

  • Support for Multiple Routing Keys in AMQP 1.0 via x-cc Message Annotation.

    AMQP 1.0 publishers now can set multiple routing keys by using the x-cc message annotation.
    This annotation allows publishers to specify a list
    of routing keys (strings) for more flexible message distribution,
    similar to the CC header in AMQP 0.9.1.

    GitHub issue: #12559

MQTT Plugin

Enhancements

  • The default MQTT Maximum Packet Size changed from 256 MiB to 16 MiB.

    This default can be overridden by configuring mqtt.max_packet_size_authenticated.
    Note that this value must not be greater than max_message_size (which also defaults to 16 MiB).

Prometheus Plugin

Enhancements

  • RabbitMQ nodes now provide a Prometheus histogram for message sizes published by applications.

    This feature allows operators to gain insights into the message sizes being published to RabbitMQ,
    such as average message size, number of messages per pre-defined bucket (which can both be computed accurately), and percentiles (which will be approximated).
    Each metric is labelled by protocol (AMQP 1.0, AMQP 0.9.1, MQTT 5.0, MQTT 3.1.1, and MQTT 3.1).

    GitHub issue: #12342

Management UI

Enhancements

  • Connection pages now display detailed AMQP 1.0 session and link information:

    1. Link names
    2. Link target and source addresses
    3. Link flow control state
    4. Session flow control state
    5. Number of unconfirmed and unacknowledged messages

    GitHub issue: #12670

  • The management UI now shows if a feature flag has a migration function (in other words, it may take time to be enabled),
    if it is experimental and whether it is supported or not. To enable an experimental feature flag,
    a user must to tick checkboxes to confirm they know what they are doing.

    GitHub issue: #12643

  • Feature flags are now enabled using asynchronous requests in the management UI.
    This means that feature flags that perform data migrations (which can take some time)
    won't block the browser tab.

    GitHub issue: #12643

Event Exchange Plugin

Enhancements

  • The rabbitmq_event_exchange plugin now can be configured to internally publish AMQP 1.0 instead of AMQP 0.9.1 messages to the amq.rabbitmq.event topic exchange.

    This allows AMQP 1.0 consumers to receive event properties containing complex types such as lists
    or maps, for example queue arguments for the queue.created
    event or client provided properties for the connection.created event.

    GitHub issue: #12714

Dependency Changes

TBD

Source Code Archives

To obtain source code of the entire distribution, please download the archive named rabbitmq-server-4.1.0.tar.xz
instead of the source tarball produced by GitHub.

RabbitMQ 4.0.4

13 Dec 18:52
bdb30ca
Compare
Choose a tag to compare

RabbitMQ 4.0.4 is a maintenance release in the 4.0.x release series.

It was re-tagged (but not rebuilt) to bdb30ca after its original release on Nov 21, 2024.
Packages were not rebuilt, only the tag was incorrect.

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.1.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

  • In rare cases quorum queue could end up without an elected leader because
    chosen candidate replica was not verified for aliveness.

    Contributed by @Ayanda-D.

    GitHub issues: #12727, #10423, #12701

  • Quorum queue follower replicas that have falled behind the leader could
    run into an exception after installing a snapshot.

    GitHub issue: #12635

  • Clusters with a large number of streams could run into confusing timeout
    exceptions.

    GitHub issue: #12693

  • Stream members could fail to start when their data directories had externally added files,
    for example, metadata of certain file systems.

    GitHub issue: #12688

  • Fetching metrics of AMQP 1.0 connections could fail with an exception.

    GitHub issue: #12700

  • Nodes using Khepri for schema data store now follow a set of rabbitmqctl reset procedures
    better aligned with those performed by nodes still using Mnesia.

    GitHub issue: #12763

Enhancements

  • Policy changes are now periodicaly re-applied (only if necessary) to quorum queues.
    Quorum queues that did not have an online elected leader at the time
    of policy change would now eventually "pick up" the settings from that policy.

    Contributed by @LoisSotoLopez.

    GitHub issue: #12667

  • Clusters with many streams and stream consumers will see a reduced per-stream CPU and network I/O
    footprint.

    GitHub issue: #12685

  • Clusters now can optionally be tagged with key-value pairs (cluster tags). The tags will
    be reported by rabbitmq-diagnostics cluster_status and the GET /api/overview HTTP API endpoint.

    Note that the Prometheus scraper API endpoint intentionally omits them because this kind of
    metadata in Prometheus is considered to be deployment and not application metadata.

    The tags are configured using rabbitmq.conf:

    cluster_tags.environment = production
    
    cluster_tags.region = us-east
    cluster_tags.az = us-east-3

    Contributed by @SimonUnge.

    GitHub issue: #12552

  • Nodes now can optionally be tagged with key-value pairs (node tags). The tags will
    be reported by rabbitmq-diagnostics status and the GET /api/overview HTTP API endpoint.

    Note that the Prometheus scraper API endpoint intentionally omits them because this kind of
    metadata in Prometheus is considered to be deployment and not application metadata.

    The tags are configured using rabbitmq.conf:

    nodes_tags.environment = production
    
    nodes_tags.region = us-east
    nodes_tags.az = us-east-3

    Contributed by @SimonUnge.

    GitHub issue: #12703

  • When a max length limit is applied to a quorum queue with a larger backlog (e.g. millions of messages),
    the deletion of excess messages now carries a significantly more moderate spike in memory footprint
    of the queue.

    GitHub issue: #12608

CLI Tools

Bug Fixes

  • rabbitmq-diagnostics check_if_any_deprecated_features_are_used now takes more deprecated features
    into account.

    GitHub issue: #12734, #12738

MQTT Plugin

Bug Fixes

  • A message with expiration (TTL) set, that was published by an AMQP 0-9-1 publusher,
    could not be converted for an MQTT consumer.

    GitHub issue: #12711

  • When x.509 (TLS) certificate-based authentication was used, two keys that controlled
    what SAN (Subject Alternative Name) fields were used to fetch client identity did not
    have any effect when used in rabbitmq.conf.

    Partially contributed by @janezturk.

    GitHub issue: #12618

Prometheus Plugin and Grafana Dashboards

Bug Fixes

Management Plugin

Enhancements

  • The endpoint that creates bindings now uses a much smaller HTTP request body
    size limit by default. Unlike the definition upload endpoint that accepts
    large definition documents, bindings do not need the generous multi-MiB limit.

    Note that the default HTTP request body size limit can be configured,
    for example, to reduce it across the board.

    GitHub issue: #12697

  • Improved alignment of optional queue arguments on the queue declaration page.

    Contributed by @markus812498.

    GitHub issue: #12678

OAuth 2 Plugin

Bug Fixes

  • When configuring multiple resource servers,
    additional_scopes_key was not taken into account, which means some scopes were not considered
    when making an authorization decision.

Contributed by @Hathoute.

GitHub issue: #12750

Debian Package

Enhancements

  • The package now lists Erlang 27.x as a supported series.

    GitHub issue: #12603

RPM Package

Enhancements

  • The package now lists Erlang 27.x as a supported series.

    GitHub issue: #12603

Dependency Changes

  • osiris was upgraded to 1.8.4

Source Code Archives

To obtain source code of the entire distribution, please download the archive named rabbitmq-server-4.0.4.tar.xz
instead of the source tarball produced by GitHub.