IDE
Download
- Download Virtual Box.
- Download Vagrant.
- Download Putty.
- Download SuperPutty.
- Download Kubernetes Starter Kit.
Run Kubernetes
- Open
~\_Lecture_k8s_starter.kit-main\ch1\1.2\k8s-min-5GiB
oncommend
- Enter
vagrant up
data:image/s3,"s3://crabby-images/ec544/ec54425e60d52f8062cc4d098812bde66c7e98fa" alt=""
- Open Virtual Box to check 4 machines
data:image/s3,"s3://crabby-images/819a8/819a8c382b4399f8d43adf5b58112c8b4463da52" alt=""
Run Kubernetes on Terminal
- Open SuperPutty - [File] - [Import Sessions] - Import
~\_Lecture_k8s_starter.kit-main\ch1\1.3\Sessions.Xml
data:image/s3,"s3://crabby-images/68b35/68b3533bebc98872ada8db1acb3694b64307fed0" alt=""
Setting
- To easy exit from the virtual machine, Open Virtual Box - [Environment Settings] - [Input] - [Virtual Machine] - Click Host Key and Press Ctrl + Alt
- To change font size of SuperPutty, Open SuperPutty and Click m-k8s from Sessions - Right click the session name in Commands - [Change Settings] - [Window] - [Apperance]
data:image/s3,"s3://crabby-images/68b35/68b3533bebc98872ada8db1acb3694b64307fed0" alt=""
data:image/s3,"s3://crabby-images/39d77/39d77306d01ba6267f8da06ab22eba375e950600" alt=""
- If you want to change Putty colour, copy and paste
_puttycolor.js
andk8s(github_SysNet4Admin) Terminal,reg
in~\_Lecture_k8s_starter.kit-main\ch8\012
to your putty folder.
data:image/s3,"s3://crabby-images/1346a/1346a994a26d2607ed9387cc7ce5a755f38c2fd9" alt=""
Pod
- Pod is union of containers.
- One pod has one or several containers to do one specific work.
Release Pod with NGINX
- Enter
kubectl run nginx --image=nginx
- Enter
Kubectl get pod
and wait until Status is changed to Running - Enter
Kubectl get pod -o wode
and copy nginx IP - Enter
curl [nginx IP]
data:image/s3,"s3://crabby-images/8f82c/8f82c7e1e64906b38dc10213c21662fac1e1cbe9" alt=""
Connect Pod from Outside
Service
- We use a service to connect a pod from Outside.
- At first, service will be connected with a NodePort.
- Then the NodePort communicates with the node.
- As a result, the service finds the pod in the node.
Expose Service
- Enter
kubectl expose pod nginx --type=NodePort --port=80
to expose a service with a port. - Enter
kubectl get service
and check your port number.
data:image/s3,"s3://crabby-images/2ed6e/2ed6e1bcf1ea4e550f4552b638cf4bbe0c02f8c3" alt=""
- Enter
kubectl get nodes -o wide
and check INTERNAL-IP.
data:image/s3,"s3://crabby-images/4410a/4410a253e158a0d555e9fb16405f01cc5c068d1a" alt=""
- Check one of IP is connected from outside like commands or web browser.
data:image/s3,"s3://crabby-images/d7df9/d7df95c694349966958fc6c9d1ec018e2d00e1a8" alt=""
Deployment
- Union of Pods
Create Deployment
- Enter
kubectl create deployment deploy-nginx --image=nginx
.
data:image/s3,"s3://crabby-images/59fb6/59fb69e5c75a2e71e0ef20561084c01e97fa9f8f" alt=""
Scale Deployment
- Enter
kubectl scale deployment deploy-nginx --replicas=3
because default replicas set is 1.
data:image/s3,"s3://crabby-images/19ae3/19ae3761952e7e54c493545bd5bd91c62371933c" alt=""
Expose Deployment
- This way is not the best way to connect with pods because you have to share your Internal IP.
- Enter
kubectl expose deployment deploy-nginx --type=NodePort --port=80
.
data:image/s3,"s3://crabby-images/3f88f/3f88f2ea9a46f11c8197ec2be3acfbca7f97a660" alt=""
Load Balancer
- We use Load Balancer to expose the Deployment with External IP.
- Enter
kubectl apply -f ~/_Lecture_k8s_starter.kit/ch2/2.4/metallb.yaml
to install MetaLib.
data:image/s3,"s3://crabby-images/67e5c/67e5c233d843aef54889870d81edd58b4efe11ab" alt=""
- Enter
kubectl create deployment chk-hn --image=sysnet4admin/chk-hn
. - Enter
kubectl scale deployment chk-hn --replicas=3
.
data:image/s3,"s3://crabby-images/51efb/51efb52890ce5ea10840646e26e5e7f1b9e23116" alt=""
- Enter
kubectl expose deployment chk-hn --type=LoadBalancer --port=80
.
data:image/s3,"s3://crabby-images/c93f8/c93f869dea06239bf5a6b7cc516ed2d54e014c9d" alt=""
- Check your External IP with web browser
data:image/s3,"s3://crabby-images/a68d3/a68d30430abe03938b6c60ea2f81a4bb892d0c7e" alt=""
Delete Deployment, Service, Pod and MetaLib
- Enter
kubectl delete deployment [Your Deployment Name]
.
data:image/s3,"s3://crabby-images/56199/56199e6404b768b167539c5d62396239aa53d0aa" alt=""
- Enter
kubectl delete service [Your Service Name]
.
data:image/s3,"s3://crabby-images/cbdd4/cbdd41c708d4a3cd6692e4ec5ed548cf1431e6e3" alt=""
- Enter
kubectl delete Pod [Your Pod Name]
.
data:image/s3,"s3://crabby-images/3eafa/3eafa6d867bb802d97f07f15c46b31f54ba24c82" alt=""
- Enter
kubectl delete -f ~/_Lecture_k8s_starter.kit/ch2/2.4/metallb.yaml
.
data:image/s3,"s3://crabby-images/7e537/7e537665264136bc77f4ecbf13ce63e6f36b59b6" alt=""
Components
Native components
- Enter
kubectl get pods -n kube-system
.
data:image/s3,"s3://crabby-images/b8a0d/b8a0d94f4ec648c1f682be13345824f2da118841" alt=""
Kubernetes Cloud Service
- EKS : Elastic Kubernetes Service from AWS
- AKS : Azure Kubernetes Service
- GKE : Google Kubernetes Engine
Issues
About Deleteing
- If your deleted pod was a real pod, then you cannot rewind.
- But if your deleted pod was in a deployment, then kubernetes rewind the pod automatically.
- If you delete a pod in mater node, kubernetes recreate it automatically.
Pods
- At first, you have to make pods and a deployment for practice with
kubectl apply -f ~/_Lecture_k8s_starter.kit/ch4/4.1/
. - Now, you have 3 deployment’s pods and 1 just pod.
data:image/s3,"s3://crabby-images/274fc/274fc6d3a3d9657cddef3aa929bb376493b612ab" alt=""
- When you delete del-pod with
kubectl delete pod [Your Pod]
, three pods will be remained. - And del-pod is removed eternally.
data:image/s3,"s3://crabby-images/55cbf/55cbff6da01a1f4e25f77c08dc4d49352db08f7b" alt=""
- When you delete a pod which is in the deployment with
kubectl delete pod [Your Delpoyment's Pod]
, three pods will be remained. - Your deployment will rewind your deleted pod automatically.
data:image/s3,"s3://crabby-images/86ae0/86ae0cebaaa76197c0a5b5f0bd0c0fc56df6dbad" alt=""
Deployment
- When you want to delete a pod which is in the deployment, enter
kubectl delete deployment [Your Deployment]
. - Your deployment will remove your all pods in that deployment.
data:image/s3,"s3://crabby-images/08028/0802881d48c4f6ca127f1220575c0bda921d910e" alt=""
Scheduler
- To delete Scheduler in master node, enter
kubectl delete pod kube-scheduler-m-k8s -n kube-system
. - Then you can see that your kubernetes create new scheduler immediately.
data:image/s3,"s3://crabby-images/be687/be6871b9af386c1576413d7ee45ce810b148477e" alt=""
About Termination
- If you terminate a worker node, kubernetes seperate pods in that worker node to others.
Kubelet
- At first, terminate first worker node with
systemctl stop kubelet
data:image/s3,"s3://crabby-images/dbe2b/dbe2b574e59bf4e1ec019c5dba322dbeca766fd4" alt=""
- You have to make pods for practice with
kubectl apply -f ~/_Lecture_k8s_starter.kit/ch4/4.1/del-deploy.yaml
. - Now, you have 3 deployment’s pods unfairly.
data:image/s3,"s3://crabby-images/be620/be6207de63ae043777a43c3715a983aaf2c099b8" alt=""
- In master node, you can also practice terminating Kubelet with
systemctl stop kubelet
andkubectl delete pod kube-scheduler-m-k8s -n kube-system
- Now your scheduler in master node is always Terminating, because your master node kubelet is stopped.
data:image/s3,"s3://crabby-images/e4713/e47130064da119625e47c25e5fe9b7d297c231b5" alt=""
- You can check, that kubelet in master node is still working well, with
kubectl create deployment nginx --image=nginx
data:image/s3,"s3://crabby-images/9b89f/9b89fe87f418182e5f7b291a072e5078037f113a" alt=""
- You can check, that scheduler in master node is still working well, with
kubectl scale deployment nginx --replicas=3
data:image/s3,"s3://crabby-images/9f458/9f45812e6f47a50f50bf989753d75866d72711d5" alt=""
- By the way, to restart our kubelet and scheduler, enter
systemctl start kubelet
data:image/s3,"s3://crabby-images/e2f67/e2f670a1723ab33f1c262b1ab9d6d4697af80662" alt=""
ContainerD
- At first, terminate containerD in first worker node with
systemctl stop containerd
data:image/s3,"s3://crabby-images/42d35/42d35ce829d4872718ed1263c0bc5a7cf1991e6d" alt=""
- You need to scale pods to 6 with
kubectl scale deployment del-deploy --replicas=6
. - Now, you have 6 deployment’s pods and those pods are working in worker node 2 and 3, not 1.
data:image/s3,"s3://crabby-images/77b90/77b90a13580e38e33049ea3dbec7b7d16b0c62b7" alt=""
- To restart containerD, enter
systemctl start containerd
.
data:image/s3,"s3://crabby-images/25fda/25fda0ec743602b56a6f52b0e61d62c2d50525f4" alt=""
- You have to rescale to see the worker node 1 in pod list with
kubectl scale deployment del-deploy --replicas=9
.
data:image/s3,"s3://crabby-images/1599b/1599b7c729b88076ce07880e52cf6fd223cbc7cb" alt=""
- In master node, you can also practice terminating ContainerD with
systemctl stop containerd
data:image/s3,"s3://crabby-images/65381/65381591be2fdcfa12e0089a0f6c1babfc5ba7ce" alt=""
- You can check, that ContainerD in master node is still working well, with
kubectl create deployment nginx --image=nginx
andkubectl delete deployment nginx
data:image/s3,"s3://crabby-images/6ad0e/6ad0eb5ebfd6dd690ec3fd5a9601eac4fa1e0c17" alt=""
- By the way, to restart our ContainerD and scheduler, enter
systemctl start containerd
and
data:image/s3,"s3://crabby-images/c3072/c3072a5704e02864ff790fd6b701e67fcd86f3d5" alt=""
Docker
- In worker node #1, you will stop ContainerD and Docker with
systemctl stop containerd
andsystemctl stop docker
. - Then your new scaled deployment is not working in worker node #1.
data:image/s3,"s3://crabby-images/a0f3a/a0f3ad05e423aff35ff487126cd13d4ddcf37a90" alt=""
- When you stoped worker node #1 more than 5 minutes, your pods in worker node #1 are terminated.
- But, those are not deleted, because there is no ContainerD.
data:image/s3,"s3://crabby-images/7ace1/7ace1151a07591aa345cb3ff0d4ec0a3683a681e" alt=""
Object
- Most objects in kubernetes has the status and spec.
- Pod : union of container
- Service : Connection Pod with outside
- Namespace : Place to publish pods, services and delpoyments
- Volume : Place to save eternal data, like pod
Edit Status
- To edit status of deployment, enter
kubectl edit deployment del-deploy
data:image/s3,"s3://crabby-images/67561/6756103c12f2db86a1663fe35b5323645c167eb7" alt=""
data:image/s3,"s3://crabby-images/31935/3193525bfeaa6d6036ccbc5d3d84a26a320ce4c9" alt=""
Apply Volume
- At first, create symlink to make log file about volume with
~/_Lecture_k8s_starter.kit/ch5/5.2/nfs-exporter.sh log
,cat /etc/exports
andcat ~/_Lecture_k8s_starter.kit/ch5/5.2/dpy-chk-log.yaml
.
data:image/s3,"s3://crabby-images/5e4d2/5e4d25b402891661eeaae97f9d369bf2baa733aa" alt=""
- Now, create deployments with
kubectl apply -f ~/_Lecture_k8s_starter.kit/ch5/5.2/dpy-chk-log.yaml
.
data:image/s3,"s3://crabby-images/5e4d2/5e4d25b402891661eeaae97f9d369bf2baa733aa" alt=""
- Now, create deployments with
kubectl apply -f ~/_Lecture_k8s_starter.kit/ch5/5.2/dpy-chk-log.yaml
.
data:image/s3,"s3://crabby-images/4cd7f/4cd7fd71d6fc0134b2ed443ffb683e22e80d6f28" alt=""
- To check your log file, first of all, you have to execute a deployment with
curl [Your Deployment IP]
. - Then you will access this deployment with
kubectl exec dpy-chk-log-655668ffb8-jl9fr -it -- /bin/bash
. - And you can access the log file with
cat audit/audit_dpy-chk-log-655668ffb8-jl9fr.log
. - You can see your execution after that command line.
data:image/s3,"s3://crabby-images/216d6/216d6c9cc433d4a840d241ab5b9a3fa359469e30" alt=""
- This log file data is eternally saved, even when we deleted deployments.
data:image/s3,"s3://crabby-images/216d6/216d6c9cc433d4a840d241ab5b9a3fa359469e30" alt=""
Short Cut
Object | Short cut |
---|---|
Pod | po |
Deployment | deploy |
Node | no |
Namespace | ns |
Service | svc |
Alias
- With alias, we can make short cut in kubernetes.
Master Node
- You can see all line of master node code with
cat ~/_Lecture_k8s_starter.kit/ch1/1.2/k8s-min-5GiB/master_node.sh
- In this master node, for example, you can use
k
likekubectl
data:image/s3,"s3://crabby-images/216d6/216d6c9cc433d4a840d241ab5b9a3fa359469e30" alt=""
- Now, we will use keq as
kubectl exec [Your Pod Number]
. - You can see the code with
cat ~/_Lecture_k8s_starter.kit/ch6/6.1/k8s_rc.sh
data:image/s3,"s3://crabby-images/f2616/f26166fe42b3ce3409577b2458f04a78f74b8a8f" alt=""
- To run this file, enter ` ~/_Lecture_k8s_starter.kit/ch6/6.1/k8s_rc.sh`.
- When you type
keq
, you can see the selection. - The default command line environment is shell, but if you want, you can change to bash with
/bin/bash
.
data:image/s3,"s3://crabby-images/0a16b/0a16b6d282d4af2d43395596ea24307b29a04abb" alt=""
Upgrade
- Before upgrading, our master node version is 1.25.0.
data:image/s3,"s3://crabby-images/f9bf9/f9bf9a11d871eef220870aa381bf7f75fd9d04c3" alt=""
Master node
- To upgrade your kubernetes, you should upgrade kubeadm with
yum upgrade kubeadm-[Your Upgrade Version] -y
, cluster withkubeadm upgrade apply [Your Upgrade Version] -y
, kubelet withyum upgrade kubelet-[Your Upgrade Version] -y
. - Now, you need to restart kubelet with
systemctl restart kubelet
andsystemctl daemon-reload
.
Worker node
- In worker node, you should upgrade kubeadm with
yum upgrade kubeadm-[Your Upgrade Version] -y
, cluster withkubeadm upgrade node
, kubelet withyum upgrade kubelet-[Your Upgrade Version] -y
- When you have different cluster between master node and worker node, you can use
kubeadm upgrade node
andkubectl -n kube-system get cm kubeadm-config -o yaml
.
data:image/s3,"s3://crabby-images/1c18c/1c18cc848b55bd97ab3c0acd5294e9a8f0880616" alt=""
- Now, you need to restart kubelet with
systemctl restart kubelet
andsystemctl daemon-reload
. - You can see upgrade result in master node with
kubectl get nodes
.
data:image/s3,"s3://crabby-images/fad7a/fad7abb3639501f9685ff6bf829db6c318508b40" alt=""
Automatic Upgrade with Ansible
- You can check the installer code for ansible with
cd _Lecture_k8s_starter.kit/ch8/009
andvi ansible-installer.sh
yum install ansible-2.9.27-1.el7 -y
will install ansible.cat <<EOF > /etc/ansible/hosts [Master] 192.168.1.10 [Workers] 192.168.1.[101:103] EOF
describes upgrading hosts.known_host
makes automatic authorization in ssh without password.
data:image/s3,"s3://crabby-images/b06f6/b06f66772050b35e98064a3a235d2ff02259ce5c" alt=""
- You should run this file with
./ansible-installer.sh
,
data:image/s3,"s3://crabby-images/c5226/c52261430c80681785e62958937086213f068652" alt=""
- There is an upgrade yaml code and you can check this with
vi k8s-upgrade.yml
. hosts
means host for upgrading.- In task, you can see
yum
and this describes we want to upgrade kubeadm, cluster and kubelet. ansible.builtin.systemd
shows, we want to restart our kubelet and reload daemon.
data:image/s3,"s3://crabby-images/b9631/b9631f3900413770a6be52fbab835c74f2834a3c" alt=""
- After you check your upgrade version, run this upgrade code with
ansible-playbook k8s-upgrade.yml
.
data:image/s3,"s3://crabby-images/dcecb/dcecb3f6ebd3e93c009fb8ca8e5a10aef400805c" alt=""
DNS
- Reference : Kubernetes DNS Query
- Use that manifest to create a Pod with
kubectl apply -f https://k8s.io/examples/admin/dns/dnsutils.yaml
.
data:image/s3,"s3://crabby-images/661d9/661d9b12f8e65786a481b52304c6dbe5f65c8966" alt=""
- Take a look inside the resolv.conf file with
kubectl exec -ti dnsutils -- cat /etc/resolv.conf
data:image/s3,"s3://crabby-images/b0298/b02987fcd479f358db864544ea1dc95e672943ad" alt=""
- Use the kubectl get pods command to verify that the DNS pod is running with
kubectl get pods --namespace=kube-system -l k8s-app=kube-dns
. - The command line will show pods, that their label is kube-dns and they are belong to namespace kube-system.
data:image/s3,"s3://crabby-images/cac32/cac32f7f1504619a0ee60b94a901dbaf89592427" alt=""
- Use the kubectl logs command to see logs for the DNS containers with
kubectl logs --namespace=kube-system -l k8s-app=kube-dns
.
data:image/s3,"s3://crabby-images/99746/99746c9cadc7511adc81f8ed88f57ea8928328f9" alt=""
etcd
- In mater node, there is Api server and etcd.
- etcd communicates with Api server for cluster status.
- You can install etcd with
~/_Lecture_k8s_starter.kit/ch8/003/install_etcdctl.sh
.
data:image/s3,"s3://crabby-images/62588/62588141fe1552806de49e61999710e66a45770d" alt=""
- Create deployments with
k apply -f _Lecture_k8s_starter.kit/ch8/003/sysnet4admin.yaml
- Sync Api server and etcd with
ETCDCTL_API=3 etcdctl --endpoints=https://[192.168.1.10]:2379 --cacert=/etc/kubernetes/pki/etcd/ca.crt --cert=/etc/kubernetes/pki/etcd/server.crt --key=/etc/kubernetes/pki/etcd/server.key get --prefix=true "" > /tmp/prefix
- Then you can see two command line,
cat /tmp/prefix | nl | tail
andcat /tmp/prefix | nl | grep -i 'pod":"sysnet4admin'
data:image/s3,"s3://crabby-images/3ab95/3ab950fa3ebef544faf7b5656a5e485f533732dc" alt=""
- When you scaled deployments, you should sync again.
data:image/s3,"s3://crabby-images/a7517/a751760ce7286e98794ab832573ecbdab1b27704" alt=""
- When you delete deployments, you should sync again, too.
data:image/s3,"s3://crabby-images/2b07f/2b07f643959b70189e4834592ea3e73cdd4fcec4" alt=""
Application
- Every application use a specific namespace, because it’s easier to delete.
Polaris
- Reference : Fairwinds
- Before practice, you need 6 normal deployments and 1 specific deployment, which belong to metallb-system namespace.
data:image/s3,"s3://crabby-images/2fbd1/2fbd1cc7f335b527ea59289114943ec25d804a74" alt=""
- Then, you need to download helm in your repository with belows.
curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3
chmod 700 get_helm.sh
./get_helm.sh
data:image/s3,"s3://crabby-images/a2930/a29303bcfbe4d9ec1ddbac631f4121609bc18502" alt=""
- Now, you can download polaris with belows.
helm repo add fairwinds-stable https://charts.fairwinds.com/stable
helm upgrade --install polaris fairwinds-stable/polaris --namespace polaris --create-namespace
data:image/s3,"s3://crabby-images/f9bad/f9badb0434e5ac4e2188ade88b04a89a7b9803ee" alt=""
- Finally, you will expose polaris dashboard with LoadBalancer in port 8080 with
k expose -n polaris deployment polaris-dashboard --type=LoadBalancer --name=polaris --port=8080
.
data:image/s3,"s3://crabby-images/90495/90495a7d09a952e1ead25597e2b1c49e810bed6a" alt=""
- Use
http://192.168.1.11:8080/
in your web browser to see your dashboard.
data:image/s3,"s3://crabby-images/93131/93131a70de27b68da25247a1f8ce8843c155195c" alt=""
Chaos Mesh
- Reference : Chaos Mesh
- Download with
curl -sSL https://mirrors.chaos-mesh.org/v2.5.1/install.sh | bash
.
data:image/s3,"s3://crabby-images/015d7/015d755881726e10c1c0b4720bc2ffcadd83ae8c" alt=""
- Use
k get svc -n chaos-mesh
to check your node port number.
data:image/s3,"s3://crabby-images/1e039/1e039dc2f817439b06c20ecf48b140033d80ffe3" alt=""
- And you can access Chaos Mesh dashboard in your web browser on
[One of Your Node IP]:[Chaos Mesh Node Port]
- Chaos Mesh is used as a lab with experiment tab.
data:image/s3,"s3://crabby-images/51e10/51e105ee3d3728917508e25e0e37388b207c8ea3" alt=""