- Introduction
- Understanding RabbitMQ Plugins
- New Plugin Configuration Feature
- Configuring Plugins for New Deployments
- Updating Existing Deployments
- Available Plugins
- Best Practices
- Troubleshooting
- FAQ
This guide provides comprehensive information on how to use the new plugin configuration feature for RabbitMQ deployments. With this feature, operators can easily enable and manage RabbitMQ plugins for both new and existing deployments.
RabbitMQ plugins extend the functionality of RabbitMQ, providing additional features such as management interfaces, monitoring capabilities, and protocol support. Plugins can be enabled or disabled to customize your RabbitMQ instance to your specific needs.
Our new plugin configuration feature allows for dynamic selection and management of RabbitMQ plugins through Blacksmith BOSH deployment manifests. This feature provides greater flexibility and easier management of RabbitMQ instances.
Key benefits:
- Configure plugins during service broker Blacksmith deployment
- Update plugin configurations for existing RabbitMQ instance deployments
- Consistent plugin management across all instances
To enable new RabbitMQ Instance deployments with configured plugins, you can easily configure plugins by specifying them in your Blacksmith genesis deployment manifest. After you deploy Blacksmith deployment, all the new RabbitMQ instances created afther Blacksmith deployed is configured with the plugins you enabled by default. Here's how:
-
Open your Blacksmith genesis deployment manifest file for the new deployment.
-
Locate the
params
section in the manifest. If it doesn't exist, create it. -
Add a
rabbitmq_plugins
list under theparams
section, specifying the plugins you want to enable. For example:params: rabbitmq_plugins: - rabbitmq_consistent_hash_exchange - rabbitmq_federation - rabbitmq_federation_management
-
Save the changes to your deployment manifest.
-
Deploy your Blacksmith environment using this manifest:
genesis deploy <your-new-environment>
-
During the deployment process, confirm that:
- The plugins property is being applied. Look for log lines indicating the addition of the specified plugins.
-
After the the Blacksmith deployment is complete, verify that the plugins are enabled:
- Create a new RabbitMQ service instance
- SSH into the newely created RabbitMQ instance
- Run
source /var/vcap/jobs/rabbitmq/env
thenrabbitmq-plugins list
to see the enabled plugins or cat /var/vcap/sys/log/rabbitmq/rabbitmq.log
which will show the enablement of the plugins
Note: The rabbitmq_management
plugin is typically enabled by default. If you need it, you don't have to explicitly include it in your list unless you're overriding a default set of plugins.
To update plugin configurations for existing RabbitMQ instance deployments:
-
Ensure that the latest BOSH release, which includes the new plugin configuration feature, has been uploaded to your BOSH director. If not, upload it using:
bosh upload-release path/to/latest-rabbitmq-forge-release.tgz
-
Update your RabbitMQ deployment manifest:
- Download and save the manifest
bosh -d rabbitmq-single-node-fcab211b-dffd-478d-8537-5ba2b7c4d5bb manifest > single-plugins-manifest.yml
- Add or modify the
plugins
property under theproperties
section of therabbitmq
job specification
For example:
jobs: - name: rabbitmq # ... properties: plugins: - rabbitmq_management - rabbitmq_prometheus
- Download and save the manifest
-
Redeploy your RabbitMQ instance using the updated manifest:
bosh -d rabbitmq-single-node-fcab211b-dffd-478d-8537-5ba2b7c4d5bb deploy single-plugins-manifest.yml
-
During the deployment process, confirm that:
- The latest release version is being used. You should see something like:
Using release 'rabbitmq-forge/1.2.6'
- The new plugins property is being applied. Look for log lines similar to:
properties: + plugins: + - rabbitmq_consistent_hash_exchange + - rabbitmq_federation + - rabbitmq_federation_management
- The latest release version is being used. You should see something like:
Note: Updating plugins may cause a brief interruption in service as RabbitMQ restarts to apply the new configuration.
Here's a list of commonly used RabbitMQ plugins:
- rabbitmq_management: Provides an HTTP-based API for management and monitoring (enabled by default)
- rabbitmq_prometheus: Exposes RabbitMQ metrics in Prometheus format
- rabbitmq_shovel: Provides a way to reliably move messages from one broker to another
- rabbitmq_federation: Provides a way to link brokers across a WAN
- rabbitmq_auth_backend_ldap: Provides support for LDAP authentication
For a complete list of available plugins, refer to the official RabbitMQ documentation.
- Only enable plugins that you need to minimize resource usage
- Test plugin configurations in a non-production environment before deploying to production
- Regularly review and update your plugin configurations to ensure they meet your current needs
- Monitor performance after enabling new plugins to ensure they don't negatively impact your RabbitMQ instance
If you encounter issues with plugin configuration:
-
Check the RabbitMQ logs for any error messages:
bosh -d rabbitmq-three-node-9b28f536-7ff6-4616-accd-7512f93bb74c ssh node/59213905-82c4-46d4-988e-c572ddb6b9b3 cat /var/vcap/sys/log/rabbitmq/rabbitmq.log
-
Verify that the plugins are correctly listed in your RabbitMQ deployment manifest
-
Ensure that the plugins you're trying to enable are compatible with your RabbitMQ version
-
If a plugin fails to enable, try enabling it manually on the RabbitMQ server to see if there are any dependency issues:
rabbitmq-plugins enable plugin_name
Q: Can I disable all plugins? A: A number of plugins are enabled by default (rabbitmq_management, rabbitmq_management_agent, rabbitmq_web_dispatch). You don't have to enable more for basic funstionality.
Q: Will enabling plugins affect performance? A: Some plugins may have a minor impact on performance. Always test in a non-production environment first.
Q: Can I enable plugins that aren't in the official RabbitMQ distribution? A: This feature is designed to work with official RabbitMQ plugins. Custom plugins may require additional configuration.
For further assistance, please contact our support team or refer to the official RabbitMQ documentation.