···
<literal>guest</literal> by default, so you should delete
this user if you intend to allow external access.
40
+
Port on which RabbitMQ will listen for AMQP connections.
···
users.extraUsers.rabbitmq = {
description = "RabbitMQ server user";
uid = config.ids.uids.rabbitmq;
···
description = "RabbitMQ Server";
wantedBy = [ "multi-user.target" ];
90
-
after = [ "network-interfaces.target" ];
100
+
after = [ "network.target" ];
92
-
path = [ pkgs.rabbitmq_server ];
102
+
path = [ pkgs.rabbitmq_server pkgs.procps ];
RABBITMQ_MNESIA_BASE = "${cfg.dataDir}/mnesia";
RABBITMQ_NODE_IP_ADDRESS = cfg.listenAddress;
107
+
RABBITMQ_NODE_PORT = toString cfg.port;
RABBITMQ_SERVER_START_ARGS = "-rabbit error_logger tty -rabbit sasl_error_logger false";
109
+
RABBITMQ_PID_FILE = "${cfg.dataDir}/pid";
RABBITMQ_ENABLED_PLUGINS_FILE = pkgs.writeText "enabled_plugins" ''
[ ${concatStringsSep "," cfg.plugins} ].
···
ExecStart = "${pkgs.rabbitmq_server}/sbin/rabbitmq-server";
118
+
ExecStop = "${pkgs.rabbitmq_server}/sbin/rabbitmqctl stop";
108
-
PermissionsStartOnly = true;
121
+
WorkingDirectory = cfg.dataDir;
125
+
rabbitmqctl wait ${cfg.dataDir}/pid
112
-
mkdir -p ${cfg.dataDir} && chmod 0700 ${cfg.dataDir}
113
-
if [ "$(id -u)" = 0 ]; then chown rabbitmq:rabbitmq ${cfg.dataDir}; fi
${optionalString (cfg.cookie != "") ''
echo -n ${cfg.cookie} > ${cfg.dataDir}/.erlang.cookie
chmod 400 ${cfg.dataDir}/.erlang.cookie
118
-
chown rabbitmq:rabbitmq ${cfg.dataDir}/.erlang.cookie
121
-
mkdir -p /var/log/rabbitmq && chmod 0700 /var/log/rabbitmq
122
-
chown rabbitmq:rabbitmq /var/log/rabbitmq
125
-
postStart = mkBefore "until rabbitmqctl status; do sleep 1; done";