How to Deploy RabbitMQ on Kubernetes

March 6, 2020

Introduction

RabbitMQ is an established, general-purpose message broker. A broker facilitates the exchange of messages between a set of distributed microservices and allows them to communicate efficiently and reliably.

Kubernetes, with its API-centric approach, is an ideal operator to deploy RabbitMQ instances in a cluster. Kubernetes’ scaling capabilities and automated container deployment enhance RabbitMQ’s dependability in an extended cluster environment.

This tutorial shows you how to install a RabbitMQ instance on Kubernetes.

Guide on how to to deploy RabbitMQ on Kubernetes.

Prerequisites

  • Access to a terminal window/ command line
  • A Kubernetes Cluster
  • The Kubernetes kubectl CLI tool

Deploy RabbitMQ on Kubernetes

Installing advanced software solutions on a Kubernetes cluster often involves creating and editing several complex configuration files.

Helm, the Kubernetes application package manager, can streamline the installation process and deploy resources throughout the cluster very quickly. To successfully deploy RabbitMQ, we will have to install the Helm package manager.

Install Helm Package Manager

Use the following command to install the latest version of Helm on your local Kubernetes cluster:

curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3
chmod 700 get_helm.sh
./get_helm.sh

Once the installation process has been completed, initiate the Helm package manager by typing the following command:

helm init

You can now use Helm to deploy resources throughout a cluster with a few short commands.

Create a Namespace for the RabbitMQ Deployment

All resources in Kubernetes are started in a namespace. Unless one is specified, the system uses the default namespace. To have better control over the deployment process use the following command to create a distinct namespace:

kubectl create namespace rabbit

You can use any DNS compatible name. The namespace we created is named: rabbit.

The system confirms that the namespace rabbit was successfully created.

The system confirms that the namespace has been created successfully.

Install RabbitMQ on Kubernetes

With Helm successfully installed and a designated namespace you are ready to start the RabbitMQ deployment process. Enter the following command to apply a default stable/rabbitmq chart from a git repository:

helm install mu-rabbit stable/rabbitmq --namespace rabbit

The command deploys RabbitMQ on the Kubernetes cluster in the default configuration. The deployment is executed in the rabbit namespace created previously.

An overview of the RabbitMQ deployment process.

The terminal provides the information you need to access the RabbitMQ management interface from your browsers such as the credentials, port number, and URL.

Check RabbitMQ Provisioning Status

The containers might take a few moments to deploy. The complete status of the provisioning sequence can confirm if a deployment was successful. To review the details of the deployment, enter the following command:

watch kubectl get deployments,pods,services --namespace rabbit

A shell within the terminal provides the details for the rabbit namespace.

The command deiplays the details and status of the RabbitMQ deployment.

Once you are ready to exit the monitoring shell press Ctrl+C.

Configure RabbitMQ Server

Settings for the RabbitMQ server and its plugins are edited within the RabbitMQ configuration files.

You can use your preferred text editor to access and configure the rabbitmq.conf file. The configuration file syntax uses the sysctl format, and there are several basic principles to adhere to:

  • The system does not execute lines that start with a # character, as it considers them to be a comment
  • You can define only one setting per line
  • The lines use a simple Key = Value structure

The rabbitmq.conf file allows you to define most of the necessary configuration items, such as ports, memory thresholds, disk space, or permissions to connect to the broker.

The RabbitMQ server source repository provides a comprehensive example of a rabbitmq.conf file with detailed comments. It is important to note that this example file represents a general guide and should be adapted to reflect the specific needs of your system.

Note: Versions preceding RabbitMQ 3.7.0 use a different configuration file name, rabbitmq.config.

Setting up RabbitMQ Management Plugin to enable GUI

The RabbitMQ management plugin is already available in the default distribution. Use the rabbitmq-plugins command to enable the service:

rabbitmq-plugins enable rabbitmq_management

Access the RabbitMQ graphical interface by using the IP and port number for the RabbitMQ server. Enter the following web location format in your browser:

http://rabbitmq-ip-or-server-name:15672/

The IP and port number were provided during the installation process.

Information about the IP and Port number for the RabbitMQ server.

The service asks for your credentials. To gain access to the UI need to enter your username and password. On new RabbitMQ installations, the default username and password are both predefined as “guest.”

RabbitMQ Management tool interface.

You now have access to a user-friendly environment that allows you to manage virtual hosts, queues, permissions, and exchanges.

How RabbitMQ works on Kubernetes?

The very purpose of Kubernetes is to orchestrate services and automate jobs in a highly distributed cluster. A messaging broker like RabbitMQ can enhance the quality of long-running tasks and stabilize vital background processes.

RabbitMQ uses the Advanced Message Queuing Protocol (AMQP) to standardize messaging between Producers, Brokers, and Consumers.

  • A Producer publishes a message to the Exchange.
  • The Exchange formats the message and forwards it to a predefined and selected Queue.
  • A Consumer then retrieves the formatted message and consumes it.
Basic RabbitMQ architecture from Producer to Consumer.

The systematic distribution of messages improves communication between loosely coupled applications and services.

Conclusion

You have successfully installed RabbitMQ on Kubernetes by using the Helm package manager. The services deployed in your cluster are now able to communicate much more efficiently than before.

You have also gained access to the RabbitMQ management plugin. The straightforward user interface helps you manage messaging queues effectively and ultimately reduces the loads and delivery times of your web application servers.

Was this article helpful?
YesNo
Vladimir Kaplarevic
Vladimir is a resident Tech Writer at phoenixNAP. He has more than 7 years of experience in implementing e-commerce and online payment solutions with various global IT services providers. His articles aim to instill a passion for innovative technologies in others by providing practical advice and using an engaging writing style.
Next you should read
How to Set Up and Run Kafka on Kubernetes
February 12, 2020

Kafka collects and structures vast amounts of data from multiple clients simultaneously. It's a great...
Read more
Introduction to Kubernetes Persistent Volumes
January 27, 2020

Persistent Volumes are used in Kubernetes orchestration when you want to preserve the data in the volume even...
Read more
6 Kubernetes Security Best Practices: Secure Your Workloads
January 23, 2020

This article presents basic security principles such as defense-in-depth and restricted privilege. Learn how...
Read more
Building Optimized Containers for Kubernetes
December 18, 2019

Container deployment took the software development world by storm. Use the outlined guidelines and learn how...
Read more