Skip to content

marcoceppi/bundle-observable-kubernetes

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

76 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Production-grade Kubernetes cluster with logging and monitoring

Overview

This is a Kubernetes bundle that also includes logging and monitoring. It is comprised of the following components and features:

  • Kubernetes (automating deployment, operations, and scaling containers)
    • Three node Kubernetes cluster with one master and two worker nodes.
    • TLS used for communication between nodes for security.
  • Etcd (distributed key value store)
    • Three node cluster for reliability.
  • Elastic stack
    • Two nodes for ElasticSearch
    • One node for a Kibana dashboard
    • Beats on every Kubernetes and Etcd node:
      • Filebeat for forwarding logs to ElasticSearch
      • Topbeat for inserting server monitoring data to ElasticSearch

By default this bundle will use whatever the default machine type for your cloud is, we recommend modifying for proper production use.

Usage

Deploy the bundle

juju deploy observable-kubernetes

This will deploy the bundle with default constraints. This is useful for lab environments, however for real-world use you should provide high CPU and memory instances to kubernetes, you do this by cloning our source repository:

git clone https://github.com/juju-solutions/bundle-observable-kubernetes.git observable-kubernetes
cd observable-kubernetes

Then modify bundle.yaml to fit your needs, it is commented for your convenience.

juju deploy .

This bundle exposes the kubernetes and kibana charms by default, meaning those charms are accessible with public addresses on most clouds. If you would like to remove external access then run the command juju unexpose kibana and juju unexpose kubernetes.

Run juju status to get the status of the cluster deployment, we recommend doing watch juju status in a separate terminal to watch the cluster come up.

  • etcd should show (leader) Cluster is healthy
  • kubernetes should show Kubernetes running for each node.

Alternate deployment methods

This bundle is enabled with an alternate method of deployment called "conjure-up". Refer to the conjure-up documentation to learn more.

sudo apt install conjure-up
conjure-up cs:~containers/observable-kubernetes to aws

Any of the applications can be scaled out post-deployment. The charms update the status messages with progress, so it is recommended to run watch juju status to monitor the charm status messages while the cluster is deployed.

Interact with your cluster post deployment

After the cluster is deployed you need to download the kubectl binary and configuration for your cluster from the Kubernetes master unit to control the cluster. To find the master unit check the juju status output or run a command on all kubernetes units to detect the leader:

Juju 1.x:

juju run --service kubernetes is-leader

Juju 2.x:

juju run --application kubernetes is-leader

Download the kubectl package from the master unit. Assuming the master is on unit 0:

juju scp kubernetes/0:kubectl_package.tar.gz .
mkdir kubectl
tar -xvzf kubectl_package.tar.gz -C kubectl
cd kubectl

Control the cluster

You now have the kubectl command and configuration for the cluster that was just created. There are several ways to specify the configuration for the kubectl command, using the --kubeconfig path/to/kubeconfig is the most direct. For more information on kubectl config see the Kubernetes user guide.

To check the state of the cluster:

./kubectl cluster-info --kubeconfig ./kubeconfig

Now you can run pods inside the Kubernetes cluster:

./kubectl create -f example.yaml --kubeconfig ./kubeconfig

List all pods in the cluster:

./kubectl get pods --kubeconfig ./kubeconfig

List all services in the cluster:

./kubectl get svc --kubeconfig ./kubeconfig

Scale out Usage

By default pods are will automatically be spread throughout the Kubernetes clusters you have deployed.

Scaling Kubernetes

To add more Kubernetes nodes to the cluster:

juju add-unit kubernetes

or specify machine constraints to create larger nodes:

juju add-unit kubernetes --constraints "cpu-cores=8 mem=32G"

Refer to the machine constraints documentation for other machine constraints that might be useful for the Kubernetes nodes.

Scaling Etcd

Etcd is used as a key-value store for the Kubernetes cluster. For reliability the bundle defaults to three instances in this cluster.

For more scalability, we recommend between 3 and 9 etcd nodes. If you want to add more nodes:

juju add-unit etcd

The CoreOS etcd documentation has a chart for the optimal cluster size to determine fault tolerance.

Scaling Elasticsearch

ElasticSearch is used to hold all the log data and server information logged by Beats. You can add more Elasticsearch nodes by using the Juju command:

juju add-unit elasticsearch

Access Kibana dashboard

The Kibana dashboard can display real time graphs and charts on the details of the cluster. The Beats charms are sending metrics to the Elasticsearch and Kibana displays the data with graphs and charts.

Get the charm's public address from the juju status command.

  • Access Kibana by browser: http://KIBANA_IP_ADDRESS/
  • Select the index pattern that you want as default from the left menu.
    • Click the green star button to make this index a default.
  • Select "Dashboard" from the Kibana header.
    • Click the open folder icon to Load a Saved Dashboard.
  • Select the "Topbeat Dashboard" from the left menu.

Setup Kibana

Known Limitations and Issues

The following are known issues and limitations with the bundle and charm code:

  • This bundle is not supported on LXD at this time because Juju needs to use a LXD profile that can run Docker containers.
  • Destroying the the Kubernetes master unit will result in loss of public key infrastructure (PKI).
  • No easy way to address the pods from the outside world.
  • The storage feature with ZFS is in Tech Preview mode and does not work with trusty at this time. You may force xenial deployment and pilot ZFS storage, however its not recommended by default.
  • Etcd installation may fail on units running Juju 1.25. There is a work-around by deploying etcd as Xenial series "--series=xenial", however you will have to deploy xenial series beats to gain monitoring of your Etcd units.

The charm told me to see the README

You've been directed here because you're deploying this etcd charm onto a pre-Xenial and non-amd64-based Ubuntu platform, and we don't have etcd and etcdctl binaries for that platform. You will need to obtain such binaries somehow yourself (e.g. by downloading and building from source), then tell Juju about those binaries as detailed below.

Usage with your own binaries

This charm supports resources, which means you can supply your own release of etcd and etcdctl to this charm. Which by nature makes it highly deployable on multiple architectures.

Supply your own binaries

juju upgrade-charm etcd --resource etcd=./path/to/etcd --resource etcdtcl=./path/to/etcdctl
juju list-resources etcd

You will see your binaries have been provided by username@local, and the charm will reconfigure itself to deploy the provided binaries.

To test the binaries (an example for amd64 hosts)

If you are simply deploying etcd, and the charm has halted demanding resources by telling you to consult the README, you can use a script contained in the charm itself.

charm pull etcd
cd etcd
make fetch_resources
...
cd resources
tar xvfz etcd*.tar.gz

Contact Information

Kubernetes details

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 80.3%
  • Shell 15.7%
  • Makefile 4.0%