官方文档 https://kubernetes.io/zh/docs/tasks/access-application-cluster/web-ui-dashboard/
Dashboard
是基于网页的Kubernetes
用户界面。 你可以使用Dashboard
将容器应用部署到Kubernetes
集群中,也可以对容器应用排错,还能管理集群资源。 你可以使用Dashboard
获取运行在集群中的应用的概览信息,也可以创建或者修改Kubernetes
资源 (如Deployment
,Job
,DaemonSet
等等)。 例如,你可以对Deployment
实现弹性伸缩、发起滚动升级、重启 Pod 或者使用向导创建新的应用。
Dashboard
同时展示了Kubernetes
集群中的资源状态信息和所有报错信息。
部署 Dashboard UI 默认情况下不会部署Dashboard
。可以通过以下命令部署:
1 kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/v2.2.0/aio/deploy/recommended.yaml
以上命令执行后会在k8s集群上创建出相应的pod和svc
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 root@k8s-master01:~ NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE dashboard-metrics-scraper ClusterIP 10.100.12.165 <none> 8000/TCP 65s kubernetes-dashboard ClusterIP 10.108.81.228 <none> 443/TCP 65s root@k8s-master01:~ kind: Service apiVersion: v1 metadata: labels: k8s-app: kubernetes-dashboard name: kubernetes-dashboard namespace: kubernetes-dashboard spec: type : NodePort ports: - port: 443 targetPort: 8443 nodePort: 30090 selector: k8s-app: kubernetes-dashboard root@k8s-master01:~ service/kubernetes-dashboard configured root@k8s-master01:~ NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE dashboard-metrics-scraper ClusterIP 10.100.12.165 <none> 8000/TCP 11m kubernetes-dashboard NodePort 10.108.81.228 <none> 443:30090/TCP 11m
在浏览器中访问
Dashboard UI登录账号 在K8S上有两类用户,人类用户和pod。人类用户的账号是在直接访问k8s的API Server时使用。而pod则时在应用于API Service交互时使用。
Dashboard的登录账号实际上是pod和API Server的交互,所以此处需要使用的登录账号为ServiceAccount的账号。
而dashboard的登录又分为token和kubeconfig
获取token登录dashboard 上一节授权中创建了一个dev-admin
这个SA,并对其进行了授权,所以其拥有了管理dev名称空间下的所有资源的能力
1 2 3 4 5 6 7 8 9 10 11 12 root@k8s-master01:~ NAME TYPE DATA AGE admin-token-6lrjw kubernetes.io/service-account-token 3 5d2h default-token-j5lt6 kubernetes.io/service-account-token 3 5d2h dev-admin-token-kx8ng kubernetes.io/service-account-token 3 38m root@k8s-master01:~ eyJhbGciOiJSUzI1NiIsImtpZCI6Ijd4OE5hMTV1VU0tUDQzRk45UUwzNWNzUDVsbTdpc2tzMEZYRUtwa1lfdmMifQ.eyJpc3MiOiJrdWJlcm5ldGVzL3NlcnZpY2VhY2NvdW50Iiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9uYW1lc3BhY2UiOiJkZXYiLCJrdWJlcm5ldGVzLmlvL3NlcnZpY2VhY2NvdW50L3NlY3JldC5uYW1lIjoiZGV2LWFkbWluLXRva2VuLWt4OG5nIiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9zZXJ2aWNlLWFjY291bnQubmFtZSI6ImRldi1hZG1pbiIsImt1YmVybmV0ZXMuaW8vc2VydmljZWFjY291bnQvc2VydmljZS1hY2NvdW50LnVpZCI6IjZkMTgxYjIxLTNiNmQtNDcyNC1iNTk0LTExZDkzYzI4ZTkzMiIsInN1YiI6InN5c3RlbTpzZXJ2aWNlYWNjb3VudDpkZXY6ZGV2LWFkbWluIn0.LCObvAqa21bjAkvewywR0m8v8V7w5GdqLxYcp9TvdEu7Woogo9mVnuWrpPtQ8Qhj_ZNrIMkgFJOn-J3jIlB_QfuAy-4T-t4nTw9ypsFSPgvLae0R_ATFIlk4xs4jJL-RLEvIVyrnoEfeqmPef39H7q2vbbFPO663QkVAfZv39cCfYn6EYOx69tTqo0Y1qf_k0lzErRNOPqSPE9KCs8Z7ozsB77s_o1owHnOol7qIoGAJzIdZPZiLW5bp20waCJMsRNR6Gx3ZiVbdS6JYWV-guSpix2GvcN7tXjlClQOKJbxxBzpJMKjFNQTth338jgI_zJdeOQRi9_sha24YSCxmbw
制作kubeconfig登录 1.获取到ServiceAccount的token
1 2 3 root@k8s-master01:~ eyJhbGciOiJSUzI1NiIsImtpZCI6Ijd4OE5hMTV1VU0tUDQzRk45UUwzNWNzUDVsbTdpc2tzMEZYRUtwa1lfdmMifQ.eyJpc3MiOiJrdWJlcm5ldGVzL3NlcnZpY2VhY2NvdW50Iiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9uYW1lc3BhY2UiOiJkZXYiLCJrdWJlcm5ldGVzLmlvL3NlcnZpY2VhY2NvdW50L3NlY3JldC5uYW1lIjoiZGV2LWFkbWluLXRva2VuLWt4OG5nIiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9zZXJ2aWNlLWFjY291bnQubmFtZSI6ImRldi1hZG1pbiIsImt1YmVybmV0ZXMuaW8vc2VydmljZWFjY291bnQvc2VydmljZS1hY2NvdW50LnVpZCI6IjZkMTgxYjIxLTNiNmQtNDcyNC1iNTk0LTExZDkzYzI4ZTkzMiIsInN1YiI6InN5c3RlbTpzZXJ2aWNlYWNjb3VudDpkZXY6ZGV2LWFkbWluIn0.LCObvAqa21bjAkvewywR0m8v8V7w5GdqLxYcp9TvdEu7Woogo9mVnuWrpPtQ8Qhj_ZNrIMkgFJOn-J3jIlB_QfuAy-4T-t4nTw9ypsFSPgvLae0R_ATFIlk4xs4jJL-RLEvIVyrnoEfeqmPef39H7q2vbbFPO663QkVAfZv39cCfYn6EYOx69tTqo0Y1qf_k0lzErRNOPqSPE9KCs8Z7ozsB77s_o1owHnOol7qIoGAJzIdZPZiLW5bp20waCJMsRNR6Gx3ZiVbdS6JYWV-guSpix2GvcN7tXjlClQOKJbxxBzpJMKjFNQTth338jgI_zJdeOQRi9_sha24YSCxmbw
2.制作kubeconfig文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 root@k8s-master01:~ User "dev-admin" set . root@k8s-master01:~ Cluster "kubernetes" set . root@k8s-master01:~ Context "dev-admin@kubernetes" created. root@k8s-master01:~ Switched to context "dev-admin@kubernetes" .
3.提取出dev-admin.conf文件使用kubeconfig登录dashboard UI