RabbitMQ

A managed instance of the RabbitMQ message broker in the latest version provided by NixOS which is 3.12 at the moment.

Configuration

The server listens for AMQP connections on the first IP of the srv interface on port 5672.

Additional configuration using the Erlang syntax can be placed in /etc/local/rabbitmq/rabbitmq.config.

We remove the guest user for security reasons.

Interaction

Service users can access the rabbitmq account with sudo -iu rabbitmq to perform administrative tasks with rabbitmqctl.

Monitoring

The default monitoring setup checks that the RabbitMQ server is healthy and responding to AMQP connections.

Feature Flags and Upgrading

RabbitMQ 3.8 introduced Feature Flags to allow rolling upgrades of clusters. Newer versions can require certain feature flags to be enabled before upgrading or they will refuse to start. There is a Sensu check which fails when there are disabled feature flags.

After upgrading a cluster, all stable feature flags need to be enabled. This is done automatically in resource groups where only one node has the rabbitmq role.

For larger clusters, enable them manually by running:

sudo -u rabbitmq rabbitmqctl enable_feature_flag all

Upgrading from NixOS 20.09 while keeping RabbitMQ 3.6.5

To be able to upgrade NixOS 20.09 machines using the rabbitmq36_5 role, we provide a way to keep the unchanged rabbitmq service running after the system upgrade. This conserves the specific rabbitmq config for the machine and cannot be used on new 24.05 machines.

The upgrade process starts with generating Nix config on the running machine. Put the generated config in /etc/local/nixos/rabbitmq365-frozen.nix.

#!/usr/bin/env sh
service=$(realpath /etc/systemd/system/rabbitmq.service)
storePath=${service%%/rabbitmq.service}
cat <<EOF
# Generated config to freeze the existing rabbitmq unit file and all dependencies
# to keep it running after an upgrade to 24.05.
{ lib, ... }:
{
  # This no-op option declaration is needed for building the 20.09 system.
  options.flyingcircus.services.rabbitmq365Frozen.service = lib.mkOption {};

  # On 20.09, this setting changes nothing. It's only effective on 24.05.
  config.flyingcircus.services.rabbitmq365Frozen.service =
    builtins.storePath $storePath;
}
EOF

After that, change the VM environment to a 24.05 edition, keep the rabbitmq36_5 role enabled and rebuild. The rabbitmq.service will stay active during the upgrade.

Changes to RabbitMQ’s configuration via NixOS options or /etc/local/rabbitmq. are not possible after the upgrade.