Skip to content

Latest commit

 

History

History
107 lines (79 loc) · 4.54 KB

README.md

File metadata and controls

107 lines (79 loc) · 4.54 KB

Zookeeper in a Kubernetes PetSet

These are the things you need to run Zookeeper cluster on Kubernetes. It's based on Zookeeper version 3.5.x which is currently in alpha, but it's been pretty stable to date.

Deployment

This example has been deployed and tested using a local Minikube setup.

Minikube is a tool that makes it easy to run Kubernetes locally. Minikube runs a single-node Kubernetes cluster inside a VM on your laptop for users looking to try out Kubernetes or develop with it day-to-day.

Minikube packages and configures a Linux VM, Docker and all Kubernetes components, optimized for local development. Minikube supports Kubernetes features such as:

  • DNS
  • NodePorts
  • ConfigMaps and Secrets
  • Dashboards

Deploying onto a Kubernetes cluster is fairly easy. There are example kubernetes Service and Pet Set files in the kube/ directory.

A Pet Set is a group of stateful pods that require a stronger notion of identity. The goal of Pet Set is to decouple this dependency by assigning identities to individual instances of an application that are not anchored to the underlying physical infrastructure.

A Pet Set requires there be {0..N-1} Pets. Each Pet has a deterministic name (PetSetName-Ordinal), and a unique identity. Each Pet has at most one pod, and each Pet Set has at most one Pet with a given identity.

A Pet Set ensures that a specified number of “pets” with unique identities are running at any given time. The identity of a Pet is comprised of:

  • a stable hostname, available in DNS
  • an ordinal index
  • stable storage: linked to the ordinal & hostname

Clustered software like Zookeeper suits itself well for a Pet Set as it relies on stable DNS names for discovery of peers for a quorum.

Please read Kubernetes Reference Documentation (http://kubernetes.io/docs/user-guide/petset/) regarding limitations for the Pet Set alpha release.

Deploy Persistent Volumes

Pet Sets require the backing of some persistent storage. This command creates some storage volumes for each of the “pets”. Normally persistent volumes would be provisioned automatically in your cloud environment, however here we're just using local HostPath directories.

$ kubectl create -f kube/zookeeper-volumes.yaml

Persistent volumes should be created successfully.

Deploy Service

Each Pet Set must expose a headless service.

$ kubectl create -f kube/zookeeper-service.yaml

Zookeeper service should be exposed.

Deploy PetSet

This command will create a PetSet and deploy the number of replicas specified. At present replicas can only be scaled through editing the PetSet configuration directly by changing the replica field, or deleting and recreating the PetSet with an altered replica configuration value. Please be sure you have the required persistent storage volumes available to match the number of replica pods.

$ kubectl create -f kube/zookeeper-petset.yaml
$ kubectl edit petset zookeeper

PetSet controller should be created.

List the Pods

Get the pods:

$ kubectl get pods
NAME          READY    STATUS    RESTARTS    AGE
zookeeper-1   1/1      Running   0           9 m
zookeeper-2   1/1      Running   0           8 m
zookeeper-3   1/1      Running   0           7 m

Required number of replica pods should be created.

Test the Cluster

Now, let's see if our zookeeper cluster is healthy. First, we will set /foo key to bar, then kill the Pod and try to get /foo from another zookeeper instance:

$ kubectl exec -ti zookeeper-1 bash

[root@zookeeper-1]# /opt/zookeeper/bin/zkCli.sh
[zk: localhost:2181(CONNECTED) 1] create /foo bar
Created /foo
[zk: localhost:2181(CONNECTED) 2] get /foo
bar

Delete the pod we just used to set the /foo value:

$ kubectl delete zookeeper-1
$ kubectl exec -ti zookeeper-2 bash

[root@zookeeper-2]# /opt/zookeeper/bin/zkCli.sh
[zk: localhost:2181(CONNECTED) 0] get /foo
bar

Check that zookeeper-1 has come back up and contains /foo value:

$ kubectl exec -ti zookeeper-1 bash

[root@zookeeper-2]# /opt/zookeeper/bin/zkCli.sh
[zk: localhost:2181(CONNECTED) 0] get /foo
bar

This shows that if one node dies, the cluster is still functioning and the deleted pod will be re-created by the PetSet with a consistent reliable naming convention.

ToDo

  • Remove bind-utils package from this zookeper container used for service discovery;
  • Create a bootstrap container that contains bind-utils and knows DNS service name for nslookup;
  • On this container start bootstrap container performs service discovery (nslookup) and passes list of peers to onStart script;