Kubernetes Installations
- Graduated Projects - Kubernetes (Orchestration)
- Incubating Projects - Prometheus (Monitoring), Fluentd (logging), rkt (Container Runtime), CNI (Networking API), Notary (Security), CoreDNS (Service Discovery), Linkerd (Service Mesh), Helm (Package Management), ...
- Sandbox Projects - Rook (Storage), SPIFFE (Identity Spec), SPIRE(Identity), Open Policy Agent (Policy), CloudEvents (Serverless), Telepresence (Tooling)
data:image/s3,"s3://crabby-images/12358/1235836c0f0d4e4d8ceab36c6fe90485a0a9c5e2" alt=""
data:image/s3,"s3://crabby-images/6eb40/6eb40611c66213ad0217f78beca5e87834437d65" alt=""
data:image/s3,"s3://crabby-images/91d5a/91d5aaa3acc7cfc3610098bfc99b0a6ae8af8493" alt=""
data:image/s3,"s3://crabby-images/bba6d/bba6d93076947640dfe182b406d18fd014a47ca0" alt=""
data:image/s3,"s3://crabby-images/f474f/f474f72618b696b129765005482b878d64eb3b8e" alt=""
data:image/s3,"s3://crabby-images/333cf/333cf0e0b516bb92d680ffee0c04bfa9f51a17c4" alt=""
data:image/s3,"s3://crabby-images/ed256/ed25667fdcdba0881afabdfca8dc7960d5591960" alt=""
data:image/s3,"s3://crabby-images/e4fd9/e4fd991afd2755a6e55bd78662a7acbf23eda46c" alt=""
data:image/s3,"s3://crabby-images/f8405/f84054c2441a2d8c0afd1ba380d2ee55588e6145" alt=""
data:image/s3,"s3://crabby-images/17211/17211442ccdc8bdc0c2ea50515940a5ae11361b1" alt=""
data:image/s3,"s3://crabby-images/f9189/f91890f93635d7f8fbb5c6fdd7e7f4bd457466c3" alt=""
data:image/s3,"s3://crabby-images/59fe3/59fe3f0e069b499f215e2fb3caa29f911e42b75b" alt=""
data:image/s3,"s3://crabby-images/5f8aa/5f8aa85f5d0d746bffa92916f0d40a9d8b35a3f4" alt=""
data:image/s3,"s3://crabby-images/b7f27/b7f275c6ea70979a4a866efc8b672f1c41bacbca" alt=""
data:image/s3,"s3://crabby-images/14f7b/14f7b9551a0a5a4456ed56fd7117490e35a0f26b" alt=""
data:image/s3,"s3://crabby-images/0800d/0800da7a579d755b15c732ba98520edf3a4eec90" alt=""
CNCF supported k8s OSS distributions
Located: https://github.com/kubernetes repositories
Described: https://github.com/kubernetes/community/blob/master/sig-cluster-lifecycle/README.md#subprojects
- bootkube - tool for launching self-hosted Kubernetes clusters
- kops - run production-grade, highly available, k8s clusters on AWS, GCE or DigitalOcean
- kube-aws - create, update and destroy Kubernetes clusters on AWS, Highly available and scalable k8s clusters backed by multi-AZ deployment and Node Pools
- kube-up - start k8s in GCE, part of Kubernetes
- kubeadm - toolkit that helps you bootstrap a best-practice Kubernetes cluster in an easy, reasonably secure and extensible way, part of Kubernetes
- kubernetes-anywhere - k8s in the cloud
- kubespray - create HA cluster on AWS, GCE, Azure, OpenStack, vSphere or Baremetal
- minikube - run Kubernetes locally, single-node k8s cluster inside a VM/Docker
data:image/s3,"s3://crabby-images/e853c/e853cd52ed1957c88c862aaeaaf66edbe69b08f6" alt=""
data:image/s3,"s3://crabby-images/1df82/1df82efdb5fee096951110917b1e6649c92d5451" alt=""
data:image/s3,"s3://crabby-images/04c73/04c7396ff00bf7eb6abd0027f852fae8aae4ded9" alt=""
data:image/s3,"s3://crabby-images/04c73/04c7396ff00bf7eb6abd0027f852fae8aae4ded9" alt=""
data:image/s3,"s3://crabby-images/13aa8/13aa83a5929a54e090f13343587b0f1c283ec613" alt=""
data:image/s3,"s3://crabby-images/35809/3580927e6ed8bbf3380d4edafa6e1301cac4bd34" alt=""
How to start with Kubernetes
Use your own laptop...
- Minikube - single node, easy, can be docker based (--vm-driver=none) or virtualization needed, addons, mount local dir to pods
- Kubeadm - official Kubernetes tool for installations, multinode, multi distro
- Kubespray - multinode, more complex, many options, HA, enterprise, multi distro
Use Public Cloud...
Many Public Cloud providers has "Kubernetes as a Service", depends on costs...
- AWS (Amazon) - EKS (Amazon Elastic Container Service for Kubernetes)
- Azure (Microsoft) - AKS (Azure Kubernetes Service)
- Google Cloud - GKE (Google Kubernetes Engine)
- https://github.com/kubernetes-incubator/kubespray
- Started by a group of independent developers as "Kargo" project
- Install Production Ready Kubernetes Cluster with HA
- Ansible based
- Kubernetes Incubated project
- Supported distributions: Container Linux by CoreOS, Debian, Ubuntu, CentOS/RHEL 7, Fedora/CentOS Atomic, openSUSE Leap 42.3/Tumbleweed
- Network Plugins: flannel, calico, canal, cilium, contiv, weave
- Many options: https://github.com/kubernetes-incubator/kubespray/tree/master/inventory/sample/group_vars
kubespray
data:image/s3,"s3://crabby-images/023f4/023f41c219fc606557c9f9b09b9815ea1c4989f1" alt=""
data:image/s3,"s3://crabby-images/ba9fc/ba9fc3caa8e6182bd8bd895ee24ec934e137245c" alt=""
data:image/s3,"s3://crabby-images/35809/3580927e6ed8bbf3380d4edafa6e1301cac4bd34" alt=""
data:image/s3,"s3://crabby-images/8f150/8f1502058deced3b5c7d754698a396eff8ab3bba" alt=""
Architecture Diagram
data:image/s3,"s3://crabby-images/62727/62727d26fc7adb0d5583b6797a59b9383412f233" alt=""
3 VMs, all 3 have etcd installed, all 3 are nodes (running pods), 2 of them run master components
kubespray demo
kubeadm
-
https://kubernetes.io/blog/2016/09/how-we-made-kubernetes-easy-to-install/
-
part of the Kubernetes distribution as of 1.4.0
-
response to criticisms of Kubernetes is hard to install
-
does not provision machines
-
https://kubernetes.io/docs/setup/independent/create-cluster-kubeadm/
-
You install Docker and the official Kubernetes packages
-
Select a master host, run kubeadm init
-
This sets up the control plane and outputs a kubeadm join […] command which includes a secure token
-
On each host selected to be a worker node, run the kubeadm join […] command from above
-
Install a pod network
data:image/s3,"s3://crabby-images/04c73/04c7396ff00bf7eb6abd0027f852fae8aae4ded9" alt=""
data:image/s3,"s3://crabby-images/04c73/04c7396ff00bf7eb6abd0027f852fae8aae4ded9" alt=""
data:image/s3,"s3://crabby-images/620ab/620abfceb68977955220269555eb25be44e8768a" alt=""
Architecture Diagram
kubeadm demo
data:image/s3,"s3://crabby-images/04c73/04c7396ff00bf7eb6abd0027f852fae8aae4ded9" alt=""
data:image/s3,"s3://crabby-images/04c73/04c7396ff00bf7eb6abd0027f852fae8aae4ded9" alt=""
data:image/s3,"s3://crabby-images/04c73/04c7396ff00bf7eb6abd0027f852fae8aae4ded9" alt=""
Thank you...
Kubernetes Installations
By Petr Ruzicka
Kubernetes Installations
- 2,038