Kubernetes for Admins
Photo by Kent Pilcher on Unsplash
Containerization
Orchestration
CI / CD
Service Mesh
Package Application
Run Application
Manage Application
Connect & Secure Application
Docker
Kubernetes
Bitbucket + ConcourseCI + Artifactory + Spinnaker
Istio
Cluster
Collection of machines:
aggregate computing power.
data:image/s3,"s3://crabby-images/571c2/571c226f4ea72a37eedcbe290ddd7d8a7faede29" alt=""
A Kubernetes cluster is controlled by a single API and can be used by that API.
Photo by Atharva Tulsi on Unsplash
References
Book: Managing Kubernetes
data:image/s3,"s3://crabby-images/ca16d/ca16df1246108171cc83c6727fcc483c604bb02f" alt=""
K8s Overview
Photo by Jenhao Hsiao on Unsplash
Basic Objects
Pods
ReplicaSets
Services
data:image/s3,"s3://crabby-images/15760/15760a7a20e0682a213d2e7bd913b662abd46bec" alt=""
Storage
Persistent Volumes
ConfigMaps
Secrets
data:image/s3,"s3://crabby-images/15271/15271c7befaa58df379788b3c981f72941967a25" alt=""
data:image/s3,"s3://crabby-images/bb2f0/bb2f0bebd17a30fd57000bc103a591fc94baebcb" alt=""
Organise Your Cluster
Namespaces
Labels
Annotations
data:image/s3,"s3://crabby-images/d769e/d769e5e3c6b0ce3e542b93ec94fdb33fdbcbdc51" alt=""
app=greatapp
checksum.kubernetes.io/
configmap=9c6537e
Useful Concepts
Deployments
Ingress
StatefulSets
data:image/s3,"s3://crabby-images/f07cd/f07cd2cfd17dd2396458f929b179a55c0e23c592" alt=""
data:image/s3,"s3://crabby-images/1581b/1581bd6b0a1bf733f20d711c45be73bbba8f7e1f" alt=""
data:image/s3,"s3://crabby-images/7972d/7972d158b64363b0913745116d6ada046f7c9f83" alt=""
Batch Workloads
Jobs
ScheduledJobs
data:image/s3,"s3://crabby-images/58176/5817668bc282c12000a936bc0711f34e88d5bbb2" alt=""
Cluster Agents & Utilities
DaemonSets
data:image/s3,"s3://crabby-images/cb110/cb110ebb13c2c322e00503652ba7123b873773cf" alt=""
on every nodes ...
Node / VM
data:image/s3,"s3://crabby-images/b79bd/b79bd7a8d0bf6440c5d165d26739dc4e710177b1" alt=""
data:image/s3,"s3://crabby-images/1443e/1443ef15c78eaa66199136bc6a035f6a271ec0fd" alt=""
Kubernetes Architecture
Photo by Ravin Vimesh on Unsplash
Concepts
Declarative Configuration
Reconciliation Loop
Dynamic Grouping
data:image/s3,"s3://crabby-images/45244/4524428fc420e9ddc4b96034ca48a0652150d313" alt=""
Desired State
Current State
data:image/s3,"s3://crabby-images/236cb/236cb915c6acfc3f76b355dc598e57431c642b17" alt=""
selector:
matchLabels:
app: Webapp
version: v2
Structure
Unix Philosophy of Many Components
API-Driven Interactions
data:image/s3,"s3://crabby-images/f41cb/f41cb59359301d8c2f71966211266489062c56e2" alt=""
data:image/s3,"s3://crabby-images/86c03/86c03f0f937f328d95b754cd8bbc0b733ec3c2d3" alt=""
Components
Master VM 1
etcd
API Server
Scheduler
Controller Manager
kubelet
kube-proxy
Worker VM 1
Docker
UI
CLI
Control Plane
kubeDNS
metrics-server
add-on
Add-on:
Kubernetes Dashboard,
automatic certificate agents,
functions as a service (FaaS) etc.
data:image/s3,"s3://crabby-images/e963d/e963d64374981d650ee4fe840398feb639b13896" alt=""
The K8s API Server
data:image/s3,"s3://crabby-images/a3b43/a3b4315394d82feb4a704e63108a2131e48e68e8" alt=""
Photo by Adi Goldstein on Unsplash
Functions of API Server
1. API Management
2. Request processing
3. Internal control loops
data:image/s3,"s3://crabby-images/705ff/705ffcc6b2465303d0761e6955ae77267498c2de" alt=""
Photo by Alvaro Reyes on Unsplash
data:image/s3,"s3://crabby-images/8a784/8a7848872127f9ad9c2cbaa1f3e0b9e0f5cae000" alt=""
Photo by Maarten van den Heuvel on Unsplash
data:image/s3,"s3://crabby-images/822aa/822aa36b7d06189015320562f1326d70d7146a73" alt=""
1. API Management
API Paths
API Discovery
OpenAPI Spec Serving
API Translation
data:image/s3,"s3://crabby-images/5a9b1/5a9b1ce73c0744b96e395c0208fc7826502e0abe" alt=""
data:image/s3,"s3://crabby-images/0bb37/0bb37fab1169b2a980b85acd18bdba495ed048f6" alt=""
2. Request Management
GET LIST POST / PUT DELETE
Type Of Request
data:image/s3,"s3://crabby-images/542ab/542ab49c88e7fdce6d2ae6a31c8094bf2390a061" alt=""
Authenticate
data:image/s3,"s3://crabby-images/d06b4/d06b446e1708dcabdf490848774ec4ae3890cc2f" alt=""
RBAC/Authorization
Life of Request
Admission Control
data:image/s3,"s3://crabby-images/58ef4/58ef40e5fd47a4eb805343777b174ca2b5b085f9" alt=""
data:image/s3,"s3://crabby-images/50649/506498afc78d43c9df08fdb255cc9b10c20003df" alt=""
data:image/s3,"s3://crabby-images/49446/4944697e1ac8064d66d5faf3f475ab69afea5606" alt=""
2. Request Management
Specialised Requests
/proxy
/exec
/attach
/logs
Watch Operations
Optimistically Concurrent Updates
Alternate Encodings
application/json
application/yaml
application/vnd.kubernetes.protobuf
Common Response Codes
202: Accepted
400: Bad Request
401: Unauthorised
403: Forbidden
409: Conflict
422: Unprocessable Entity
data:image/s3,"s3://crabby-images/1e089/1e0898f07eaf3ee396db52838f5172add324ab3c" alt=""
data:image/s3,"s3://crabby-images/3e372/3e3727d250693eb2024352635567ca1680d5bd66" alt=""
data:image/s3,"s3://crabby-images/8637d/8637dba1a7f6e496f69cb7502d3a803708382c59" alt=""
3. Internal control loops
API Server Internals
data:image/s3,"s3://crabby-images/f636b/f636ba4a83c6c018c209356fef065a4c295fd366" alt=""
Custom Resource Definition
Debugging the API Server
Basic Logs
Audit Logs
Activating Additional Logs
Debugging kubectl Requests
data:image/s3,"s3://crabby-images/f21a5/f21a502714f9a4956a5b4a3c626a3435bda99026" alt=""
data:image/s3,"s3://crabby-images/98fee/98fee53c2f2c6866dcf05fab658e0f37570c9480" alt=""
data:image/s3,"s3://crabby-images/33a9f/33a9f508573a0d14020ae40e49c40c59932f282f" alt=""
data:image/s3,"s3://crabby-images/01e11/01e118f5ddf2b2a4cc3c302ace068f724f048540" alt=""
Scheduler
Photo by Curtis MacNewton on Unsplash
Scheduling Process
Scheduler
data:image/s3,"s3://crabby-images/9dade/9dade2f3b12a7400734ef5639725dd566d8f07b7" alt=""
nodeName is missing
Pod
data:image/s3,"s3://crabby-images/60f5b/60f5bdef933635fe1b6617f87215b5bf827eed69" alt=""
data:image/s3,"s3://crabby-images/60f5b/60f5bdef933635fe1b6617f87215b5bf827eed69" alt=""
data:image/s3,"s3://crabby-images/60f5b/60f5bdef933635fe1b6617f87215b5bf827eed69" alt=""
data:image/s3,"s3://crabby-images/60f5b/60f5bdef933635fe1b6617f87215b5bf827eed69" alt=""
Node
kubelet
Docker
Get list of all healthy nodes
Filter Nodes based on Predicates
Prioritise/score Nodes
Get Best scored nodes
Choose a node (Round Robin)
Controlling Scheduling
Node Selectors
Node Affinity
Taints and Tolerations
data:image/s3,"s3://crabby-images/4df66/4df662bb227bbda731d1e9c0e7edf33ad3e69f3e" alt=""
Go
XL
SUV
affinity:
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
# foo == A
- key: foo
operator: In
values:
- A
# bar != C
- key: bar
operator: NotIn
values:
- C
kind: Pod
spec:
nodeSelector:
nvme-ssd: true
data:image/s3,"s3://crabby-images/28726/287269ef3225ce36838045cef8e2024bccc1cae2" alt=""
data:image/s3,"s3://crabby-images/258bc/258bc178b28367ad4bcbf46a26390f27b7fa406f" alt=""
data:image/s3,"s3://crabby-images/e42f6/e42f6cb4b95aacc9ec28f63611c8c8ed541df1d8" alt=""
data:image/s3,"s3://crabby-images/dda34/dda3488eb056461f9da7b3c5eb1f9fc45f52fd8b" alt=""
Installing Kubernetes
data:image/s3,"s3://crabby-images/e4844/e4844df6a0b6cf8c0b62911b4deddf0b9dfba71c" alt=""
Photo by Chad Kirchoff on Unsplash
kubeadm
Requirements
kubelet
Control Plane
Pre-flight Checks
kubeadm Config
Certificates
etcd
kubeconfig
Taints
Worker Nodes
Add-Ons
Phases
High Availability
Upgrades
Authentication and User Management
Authorization
Admission Control
Networking
Monitoring Kubernetes
Disaster Recovery
Extending Kubernetes
Kubernetes Overview
By Ashish Pandey
Kubernetes Overview
About how Kubernetes is architected, installed and maintained.
- 392