驗證自建的 K8s

今日雖然是鐵人賽的最後一篇,但不是 KK8s 的最後一篇~ 學不完,只怕學不來 XDD

安心一下,先看下目前叢集狀態

[vagrant@kk8s-1 ~]$ kubectl get nodes -o wide
NAME     STATUS   ROLES    AGE   VERSION   INTERNAL-IP      EXTERNAL-IP   OS-IMAGE                KERNEL-VERSION              CONTAINER-RUNTIME
kk8s-1   Ready    master   47h   v1.12.2   192.168.42.191   <none>        CentOS Linux 7 (Core)   3.10.0-862.2.3.el7.x86_64   cri-o://1.11.8
kk8s-2   Ready    <none>   24h   v1.12.2   192.168.42.192   <none>        CentOS Linux 7 (Core)   3.10.0-862.2.3.el7.x86_64   cri-o://1.11.8
kk8s-3   Ready    <none>   24h   v1.12.2   192.168.42.193   <none>        CentOS Linux 7 (Core)   3.10.0-862.2.3.el7.x86_64   cri-o://1.11.8
[vagrant@kk8s-1 ~]$ kubectl get all --all-namespaces
NAMESPACE     NAME                                 READY   STATUS    RESTARTS   AGE
kube-system   pod/coredns-576cbf47c7-dgktb         1/1     Running   0          47h
kube-system   pod/coredns-576cbf47c7-vv7rc         1/1     Running   0          47h
kube-system   pod/etcd-kk8s-1                      1/1     Running   1          2d
kube-system   pod/kube-apiserver-kk8s-1            1/1     Running   2          2d
kube-system   pod/kube-controller-manager-kk8s-1   1/1     Running   0          2d
kube-system   pod/kube-flannel-ds-amd64-cnsl2      1/1     Running   0          47h
kube-system   pod/kube-flannel-ds-amd64-qdqls      1/1     Running   0          25h
kube-system   pod/kube-flannel-ds-amd64-sr4zj      1/1     Running   0          25h
kube-system   pod/kube-proxy-bjvkj                 1/1     Running   0          25h
kube-system   pod/kube-proxy-hrsdw                 1/1     Running   0          2d
kube-system   pod/kube-proxy-kl959                 1/1     Running   0          25h
kube-system   pod/kube-scheduler-kk8s-1            1/1     Running   2          2d

NAMESPACE     NAME                 TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)         AGE
default       service/kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP         2d
kube-system   service/kube-dns     ClusterIP   10.96.0.10   <none>        53/UDP,53/TCP   2d

NAMESPACE     NAME                                     DESIRED   CURRENT   READY   UP-TO-DATE   AVAILABLE   NODE SELECTOR                     AGE
kube-system   daemonset.apps/kube-flannel-ds-amd64     3         3         3       3            3           beta.kubernetes.io/arch=amd64     47h
kube-system   daemonset.apps/kube-flannel-ds-arm       0         0         0       0            0           beta.kubernetes.io/arch=arm       47h
kube-system   daemonset.apps/kube-flannel-ds-arm64     0         0         0       0            0           beta.kubernetes.io/arch=arm64     47h
kube-system   daemonset.apps/kube-flannel-ds-ppc64le   0         0         0       0            0           beta.kubernetes.io/arch=ppc64le   47h
kube-system   daemonset.apps/kube-flannel-ds-s390x     0         0         0       0            0           beta.kubernetes.io/arch=s390x     47h
kube-system   daemonset.apps/kube-proxy                3         3         3       3            3           <none>                            2d

NAMESPACE     NAME                      DESIRED   CURRENT   UP-TO-DATE   AVAILABLE   AGE
kube-system   deployment.apps/coredns   2         2         2            2           2d

NAMESPACE     NAME                                 DESIRED   CURRENT   READY   AGE
kube-system   replicaset.apps/coredns-576cbf47c7   2         2         2       2d
查看 API 資訊:https://192.168.42.191:6443/api/v1

今日來做個基本驗證,採用過去用過的 app yaml

kubectl apply -f https://raw.githubusercontent.com/kubernetes/website/master/content/en/examples/application/nginx-app.yaml

觀察部署狀況

[vagrant@kk8s-1 ~]$ kubectl get all -n default
NAME                            READY   STATUS    RESTARTS   AGE
pod/my-nginx-5c689d88bb-68kbs   1/1     Running   0          35s
pod/my-nginx-5c689d88bb-wnmr9   1/1     Running   0          35s
pod/my-nginx-5c689d88bb-x7qqg   1/1     Running   0          35s

NAME                   TYPE           CLUSTER-IP    EXTERNAL-IP   PORT(S)        AGE
service/kubernetes     ClusterIP      10.96.0.1     <none>        443/TCP        46h
service/my-nginx-svc   LoadBalancer   10.99.29.64   <pending>     80:32031/TCP   35s

NAME                       DESIRED   CURRENT   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/my-nginx   3         3         3            3           35s

NAME                                  DESIRED   CURRENT   READY   AGE
replicaset.apps/my-nginx-5c689d88bb   3         3         3       35s

#######
[vagrant@kk8s-1 ~]$ kubectl get endpoints -n default
NAME           ENDPOINTS                                   AGE
kubernetes     192.168.42.191:6443                         46h
my-nginx-svc   10.244.1.2:80,10.244.1.3:80,10.244.2.2:80   3m12s
# 上面狀態中,可以看見 service/my-nginx-svc NodePort = 32031
# 查看下自己的系統網路層 Listen 資訊
[vagrant@kk8s-1 ~]$ ss -anut |grep LISTEN |grep 32031
tcp    LISTEN     0      128      :::32031                :::*
[vagrant@kk8s-1 ~]$
[vagrant@kk8s-1 ~]$
[vagrant@kk8s-1 ~]$ sudo lsof -i :32031
COMMAND     PID USER   FD   TYPE  DEVICE SIZE/OFF NODE NAME
kube-prox 13473 root    6u  IPv6 9834316      0t0  TCP *:32031 (LISTEN)
[vagrant@kk8s-1 ~]$

來訪問 http://master-ip:32031 失敗中...

失敗中...
失敗中...
失敗中...
afu@Ichirode-MacBook-Pro$ curl http://192.168.42.191:32031
curl: (55) getpeername() failed with errno 22: Invalid argument

到這個節骨眼,過程中的除錯仍徒勞無功,看來很需要再回顧自己不足之處~ 自己還得要加油!

今日在除錯的過程中,發現未來有幾個面向,還要持續探索~

  • K8s Dashboard

  • cAdvisor

  • HeapsterInfluxDB、grafana

  • CNI

  • CRI

謝謝朋友這次鼓吹我參加鐵人賽,不然壓根子沒想到參加鐵人賽活動! 我這次參加的鐵人賽的概念,就是將讀書、讀文章的心得寫下來,所以很多都是概念文~ 至於文章的順序,雖是隨想而決定,但基本上會是將當下有關聯的 key 去探索研讀,相對不像是標準網誌般有章節順序概念去呈現篇文。

謝謝這三十天的機會,後續就鞭策自己!

Last updated