Kubernetes Introduction
PanChuan 2018.11.08
data:image/s3,"s3://crabby-images/9cd41/9cd41cf0b49c65bfda0f4e89def14c3203db6b6f" alt=""
Outline
- Kubernetes Overview
- Kubernetes Objects
- Kubernetes Work Mechanism
Kubernetes Overview
-
Kubernetes is an open-source system for automating deployment, scaling, and management of containerized applications
-
It groups containers that make up an application into logical units for easy management and discovery
Kubernetes Overview
data:image/s3,"s3://crabby-images/bf768/bf76815d7bff4da9d228cadcc414e5877e4cf7d9" alt=""
Kubernetes is Greek for pilot or hemlsman (the person holding the ship's steering wheel)
Kubernetes History
data:image/s3,"s3://crabby-images/2e89b/2e89b166b3c7735de43fe62cd34fdc409368d3ae" alt=""
2003
2013
2014
Kubernetes History
- 2014: Key Players Joined K8s community.
Microsoft/RedHat/IBM/Docker
- 2015: V1.0 release & CNCF
- 2016: The year kubernetes goes mainstream
- 2017: Enterprise Adoption & Support
https://blog.risingstack.com/the-history-of-kubernetes/
K8S Trends
data:image/s3,"s3://crabby-images/96efa/96efa85b5e3463a5a00392ceed3a79d12a01e3b1" alt=""
Kubernetes Needs Backgroud
- Monoliths app -> Microservice app
- Becomes too complex when doing configuration/deployment/management
- Need automation
Kubernetes high-level
data:image/s3,"s3://crabby-images/45185/4518508c4aa3b0080f05c307be6075a444198dc8" alt=""
- k8s expose the whole DC as a single deployment platform
- can be thought as an operating system for the cluster
Kubernetes Features
- Service discovery and load balancing
- Automatic binpacking
- Self-healing
- Automated rollouts and rollbacks
- Storage orchestration
- Horizontal scaling
- Batch execution
- Secret and configuration management
Kubernetes Benefits
- Simplify application deployment.
- Achieving better utilization of hardware.
- Better sleeping (self-healing, auto-scaling).
- DevOps to NoOps
Kubernetes Architecture
data:image/s3,"s3://crabby-images/614f0/614f0abea02bd18cdd905dcf2e8dfd80e54d4564" alt=""
Container Runtime: Docker, rkt or else
Kubernetes Objects
- K8S objects are persistent entities in k8s system, these entities represent the state of cluster
- Post your desired state to Kubernetes API
Describe Objects
- Provide the object spec use json/yaml file.
apiVersion: apps/v1 # for versions before 1.9.0 use apps/v1beta2
kind: Deployment
metadata:
name: nginx-deployment
spec:
selector:
matchLabels:
app: nginx
replicas: 2 # tells deployment to run 2 pods matching the template
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:1.7.9
ports:
- containerPort: 80
Pods
- Pods are the central and most important concept
- encapsulated with one or more container, run and scheduled as smallest unit
data:image/s3,"s3://crabby-images/9fb59/9fb59627dfc862d7c3c514d8ab7fafbf09975d27" alt=""
why need Pods
- Containers are designed to run only a single process per container.
- Multiple containers are better than one container running multiple process.
- take the advantage of all the features container provide, meanwhile giving the process the illusion of running together
Pods feature
data:image/s3,"s3://crabby-images/80cc8/80cc881ab8d769d41f99e2ec384c42ca3af72f65" alt=""
- containers in pods are not so isolated by
sharing Linux namespace
- same network interface and hostname
- Flat network between pods (No NAT)
Create a Pod
apiVersion: v1
kind: Pod
metadata:
name: nginx
labels:
env: test
name: nginx
spec:
containers:
- image: docker-registery.itv.qiyi.domain/nginx:latest
name: nginx
ports:
- containerPort: 80
protocol: TCP
kubectl create -f ningx.yaml
Don't Abuse Pods
- Pods are relatively lightweight
- A pod is also the basic unit of scaling
- Typical Multi-container pods: sidecar containers
data:image/s3,"s3://crabby-images/e4dfc/e4dfcdfd346cd656feb02992127f0feb80ef8239" alt=""
Pods Lables
- A label is an arbitrary key-value pair attach to a resource
- Use label-selector to select specific resource
data:image/s3,"s3://crabby-images/3e275/3e275074d6b32ae4616b003ef5976d3f5dc834b2" alt=""
ReplicaSets
- Don't create pods directly, create ReplicaSets /Deployment instead
- RS keeps Pods running automatically and healthy
- 3 essential parts of a RS: A label selector, A replica count, A pod template
data:image/s3,"s3://crabby-images/2138e/2138e2d6587cce1a99cdebc72c5d820f94b6cf07" alt=""
Container Probe
- liveness probe & readness Probe
- three mechanisms to probe a container:
- HTTP Get probe (check code status)
- TCP socket (check if can connect)
- Exec cmd (check ret status)
Deployments
- A higher-level resource meat for deploying application and updating them declaratively
data:image/s3,"s3://crabby-images/b34a6/b34a61abd51ba628245aa9d573ac5c41c13fa7aa" alt=""
Deployments
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-demo
spec:
replicas: 3
template:
metadata:
name: nginx-demo
labels:
app: nginx
env: test
spec:
containers:
- image: docker-registry.itv.qiyi.domain/nginx:latest
name: nginx-demo
Service
- Pods are ephemeral, needs a way to provide stable service
- Use label-selector to organize pods
- Each service has an IP:Port that never change while the service exists
data:image/s3,"s3://crabby-images/2819e/2819ef8adb5bd551805269a94c9b012b7014f058" alt=""
Service
apiVersion: v1
kind: Service
metadata:
name: nginx
spec:
ports:
- port: 80
targetPort: 8080
selector:
app: nginx
kubectl get svc
- cluster IP is virtual and only accessible inside the cluster, can't ping
Service Discovery
- through Environment variables. Pods running order matters
- through DNS
epginfo.product.svc.cluster.lcoal
Expose service to external
- NodePort, each cluster node opens a port on the node and redirect traffic to the underlying service
- LoadBalancer, an extension of the NodePort
- Ingress, operates at the HTTP level, routes different path to different service
NodePort :
=======
apiVersion: v1
kind: Service
metadata:
name: kubia-nodeport
spec:
type: NodePort
ports:
- port: 80
targetPort: 8080
nodePort: 30123
selector:
app: kubia
service Load balancer
data:image/s3,"s3://crabby-images/ad425/ad425f215777dfd94af28be0011176e0699103c3" alt=""
service Ingress
data:image/s3,"s3://crabby-images/75c9a/75c9abf9937b78a957f97eb8258844170d56ab73" alt=""
Ingress controller: Nginx, Traefik, Kong, HAProxy
DaemonSet
- Run exactly one instance of a pod on every worker node
- Example: logCollector, kube-proxy, consul-agent
Job
- Job performs a single completable task
apiVersion: batch/v1
kind: Job
metadata:
name: batch-job
spec:
template:
metadata:
labels:
app: batch-job
spec:
restartPolicy: OnFailure
containers:
- name: main
image: luksa/batch-job
CronJob
- Schedule Jobs to run periodically or sometime in the future
apiVersion: batch/v1beta1
kind: CronJob
metadata:
name: batch-job-every-fifteen-minutes
spec:
schedule: "0,15,30,45 * * * *" // Linux cron table syntax
jobTemplate:
spec:
template:
metadata:
labels:
app: periodic-batch-job
spec:
restartPolicy: OnFailure
containers:
- name: main
image: luksa/batch-job
Namespace
- Kubernetes groups objects into namespace
- Example: prod/staging/dev
- some resource is cluster-level and doesn't belong to any namespace. Node/PersistemVolume ect.
Other Resources
- ConfigureMap
- Secrets
- Persistent Volumes
....
K8S Mechanism
data:image/s3,"s3://crabby-images/ec4ab/ec4ab6eb25a4a9e70285cb89c005210fcec1cb72" alt=""
- Master node and work node components:
- ADD-ON components:
- DNS server
- Dashboard
- CNI net plugin
- Heapster
Etcd
- Kubernetes store all cluster state and metadata in ectd
- API server is the component that talk with etcd
data:image/s3,"s3://crabby-images/6d010/6d010342d234e23cf96e60b6cf68cdcf649d2495" alt=""
data:image/s3,"s3://crabby-images/ce5e7/ce5e741500669dc35fb17fdcc5fd0d0cd3e7345f" alt=""
data:image/s3,"s3://crabby-images/46ddb/46ddbf73326422a0f414c973a3346d053785cd1b" alt=""
API Server
data:image/s3,"s3://crabby-images/cdfff/cdffff17e428ada9df7dddd1923afacc7e2bbd4e" alt=""
- Api Server is the central component used by all other components
- Api Server clients can request to be notified when a resource is created, modified or deleted (http streaming watch)
Scheduler
- A scheduler waits for newly created pods by watching api server
- Scheduler update the pod definition by api and not talk to kubelet running on work node
- Schedule algorithm is configurable and customized scheduler is support
data:image/s3,"s3://crabby-images/34ffc/34ffc253748d4aaa16461193cab177ba5b3e6cb6" alt=""
Controller manager
- Almost each kind resource has a corresponding controller
- controller make sure the actual state of the system converge toward the desired state
data:image/s3,"s3://crabby-images/b3294/b3294be5fa8bc108938069cae98790b13a0bff06" alt=""
any possible changes trigger the controller to recheck the desired vs. actual replica count and act accrodingly
Kubelet
- Kubelet is the component responsible for everything running on a worker node
- Kubelet create containers and monitors running containers and reports their status, events, and resource consumption to API server
Cooperate
data:image/s3,"s3://crabby-images/030ec/030ecd73d777d79fa84e8e3a57d08c9ba249047c" alt=""
Kube-Proxy
- Everything related to service is handled by kube-proxy process running on each node
- Kube-proxy create vIP:port in iptables rules when a new service created (through API Server)
data:image/s3,"s3://crabby-images/4cbf2/4cbf285a2abef3e13704bb2c93d376f2f8fd35ec" alt=""
Proxy-Mode: userspace
data:image/s3,"s3://crabby-images/617a4/617a4a0cb8f92125e10c4ce9c0e14884cd7f5686" alt=""
Proxy-Mode: iptables
data:image/s3,"s3://crabby-images/eab22/eab22bcc265d6052b49b649749d604025ca3ae5d" alt=""
Proxy-Mode: ipvs (v1.9 beta)
data:image/s3,"s3://crabby-images/9cb04/9cb045910edb9dac86fc3e14126878ef6dc6f831" alt=""
- based on ipvs kernel modules hook function
data:image/s3,"s3://crabby-images/3de99/3de992aa762d6fe1a4489dfa19c08fc51be93cb2" alt=""
K8S Control Plane HA
- Run multiple master nodes for HA
- API server can run multiple instance
- Controller Manager and Scheduler run as leader and standing by.
Reference
- https://kubernetes.io
- <Kubernetes In Action>
The End
QA
Kubernetes Introduction
By panchuan
Kubernetes Introduction
- 1,290