Skip to content

2 replicas RabbitMQ that runs on a host with local mount, with stable DNS names using peer discovery plugin

Notifications You must be signed in to change notification settings

yamina/StatefulSet-RabbitMQ-Kubernetes

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 

Repository files navigation

StatefulSet-RabbitMQ-Kubernetes

Implementation of 2 replicas of RabbitMQ that are running on a host with local mount (for each replica), with stable DNS names using peer discovery plugin - survives pods restarts (+ the data survives)

This YAML file contains:

  • NodePort service to expose the amqp protocol + management protocol
  • Headless service to provide each pod a stable DNS name
  • ConfigMap to change some configurations (and also set the peer discovery configuration)
  • 2 Persistent volumes - one for each replica (as currently local volume doesn't support dynamic provisioning), each one refers to a local disk on the host, bounded to that specific host (it's name is ubuntukuber, change it to your node name). ** Basically, we could create a multi host cluster, but we'll have to bound pods to be scheduled on the specific host (to find the host filesystem) - this was not tested by me. (it's all about nodeAffinity)
  • StatefulSet that besides mapping the config directory, it maps the data folder of the rabbit MQ to our volume.
  • RABBITMQ_NODENAME is set to the fully qualified cluster dns name (that the headless service provides)

Base YAML was taken from https://github.com/rabbitmq/rabbitmq-peer-discovery-k8s/blob/master/examples/k8s_statefulsets/rabbitmq_statefulsets.yaml and was expanded to host names + the persistent local storage

*Note - it's advised to use a better solution for storage for bare-metal k8s, for example either NFS share, https://ceph.com/, https://docs.gluster.org/en/latest/

About

2 replicas RabbitMQ that runs on a host with local mount, with stable DNS names using peer discovery plugin

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published