Skip to content
This repository has been archived by the owner on Feb 6, 2019. It is now read-only.

Latest commit

 

History

History
66 lines (47 loc) · 2.49 KB

README.md

File metadata and controls

66 lines (47 loc) · 2.49 KB

#Rocket.Chat on Kubernetes

README still under redaction

As of now High-Availability is not available, only one instance of each component is launched. Using MongoDB with replica sets is a bit tricky to implement in Docker so it has not been in the scope of this project yet.

The database currently use the **emptyDir** volume directive, if you want data persistence across node migration you should change it accordingly, like to use block storage endpoint.

The deployment is pretty straight-forward, clone the repo first.

$ git clone https://github.com/BastienM/rocketchat-kubernetes.git
$ cd rocketchat-kubernetes

Edit app-deployment.yaml and app-ingress.yaml to replace chat.example.com with your own domain.

And as SSL encryption is enabled by default you must provide your certificat and key in app-secrets.yaml

$ cat /path/to/crt | base64
# then past it into data.tls.crt

$ cat /path/to/key | base64
# then past it into data.tls.key

Edit MongoDB_HA/storage.yaml to replace the google cloud SSD by the solution that you want. There are drivers for AWS, Azure, Google Cloud, GlusterFS, OpenStack Cinder, vSphere, Ceph RBD, and Quobyte. More informations on how to use it can be found here.

You can also deploy a single pod mongoDB with database-deployment.yaml and database-service.yaml. In that case replace mongodb://mongo-0.mongo,mongo-1.mongo,mongo-2.mongo:27017/rocketchat?replicaSet=rs0 in app-deployment.yaml by mongodb://rocketchat-database:27017/rocketchat

If you use RBAC you need to bind a cluster role for your application :

  kubectl create clusterrolebinding cluster-view \
  --clusterrole=view \
  --serviceaccount=default:default

Then you can start deploying the pods.

$ kubectl create -f MongoDB_HA/storage.yaml
$ kubectl create -f MongoDB_HA/headless_service.yaml
$ kubectl create -f MongoDB_HA/MongoDB_statefulset.yaml
$ kubectl create -f app-secrets.yaml
$ kubectl create -f app-service.yaml
$ kubectl create -f app-deployment.yaml
$ kubectl create -f ingress-deployment.yaml
$ kubectl create -f app-ingress.yaml

The ingress controller act like a internal frontend proxy for the pods, so to access the application you must first find on which node it is running.

$ kubectl get po -o wide

And to test if everything is working all right.

$ curl --resolve chat.example.com:443:<node-ip> https://chat.example.com