Dashboard介绍
前面所有的操作我们都是通过命令行工具 kubectl 完成的。为了提供更丰富的用户体验,Kubernetes 还开发了一个基于 Web 的 Dashboard,用户可以用 Kubernetes Dashboard 部署容器化的应用、监控应用的状态、执行故障排查任务以及管理 Kubernetes 各种资源。
在 Kubernetes Dashboard 中可以查看集群中应用的运行状态,也能够创建和修改各种 Kubernetes 资源,比如 Deployment、Job、DaemonSet 等。用户可以 Scale Up/Down Deployment、执行 Rolling Update、重启某个 Pod 或者通过向导部署新的应用。Dashboard 能显示集群中各种资源的状态以及日志信息。
可以说,Kubernetes Dashboard 提供了 kubectl 的绝大部分功能,大家可以根据情况进行选择。
安装命令
kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/v2.3.1/aio/deploy/recommended.yaml
设置访问端口
kubectl edit svc kubernetes-dashboard -n kubernetes-dashboard
type: ClusterIP 改为 type: NodePort
找到端口,在安全组放行
kubectl get svc -A |grep kubernetes-dashboard
创建访问账号
#创建访问账号,准备一个yaml文件; vi dash.yaml
apiVersion: v1
kind: ServiceAccount
metadata:
name: admin-user
namespace: kubernetes-dashboard
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: admin-user
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: cluster-admin
subjects:
- kind: ServiceAccount
name: admin-user
namespace: kubernetes-dashboard
执行
kubectl apply -f dash.yaml
获取令牌
kubectl -n kubernetes-dashboard get secret $(kubectl -n kubernetes-dashboard get sa/admin-user -o jsonpath="{.secrets[0].name}") -o go-template="{{.data.token | base64decode}}"
dashboard界面结构
Dashboard 的界面很简洁,分为三个大的区域。
1.顶部操作区
在这里用户可以搜索集群中的资源、创建资源或退出。
2.左边导航菜单
通过导航菜单可以查看和管理集群中的各种资源。菜单项按照资源的层级分为两类:
Cluster 级别的资源
Namespace 级别的资源 (加了N标志的都是跟名称空间相关的)
默认显示的是 default Namespace,可以进行切换
3.中间主体区
在导航菜单中点击了某类资源,中间主体区就会显示该资源所有实例,比如点击 Pods。
典型使用场景
1.部署pod
用户可以直接输入要部署应用的名字、镜像、副本数等信息;也可以上传 YAML 配置文件。如果是上传配置文件,则可以创建任意类型的资源,不仅仅是 pod。
对于每种资源,都可以点击右边的...
按钮执行各种操作。
比如点击 编辑 可直接修改资源的配置,保存后立即生效,其效果与 kubectl edit 一样。
2.查看资源详细信息
点击某个资源实例的名字,可以查看到详细信息,其效果与 kubectl describe 一样。
3.查看 Pod 日志
在 Pod 及其父资源(DaemonSet、ReplicaSet 等)页面点击下方按钮,可以查看 Pod 的日志,其效果与 kubectl logs 一样。
效果如下
4.进入pod
Kubernetes Dashboard 界面设计友好,自解释性强,可以看作 GUI 版的 kubectl