云计算
前面章节 kubernetes 所有的操作我们都是通过命令行工具 kubectl 完成的。为了提供更丰富的用户体验,kubernetes 还开发了一个基于 web 的 dashboard,用户可以用 kubernetes dashboard 部署容器化的应用、监控应用的状态、执行故障排查任务以及管理 kubernetes 各种资源。
在 kubernetes dashboard 中可以查看集群中应用的运行状态,也能够创建和修改各种 kubernetes 资源,比如 deployment、job、daemonset 等。用户可以 scale up/down deployment、执行 rolling update、重启某个 pod 或者通过向导部署新的应用。dashboard 能显示集群中各种资源的状态以及日志信息。
可以说,kubernetes dashboard 提供了 kubectl 的绝大部分功能,大家可以根据情况进行选择。
安装
kubernetes 默认没有部署 dashboard,可通过如下命令安装:
kubectl create -f https://raw.githubusercontent.com/kubernetes/dashboard/master/src/deploy/recommended/kubernetes-dashboard.yamldashboard 会在 kube-system namespace 中创建自己的 deployment 和 service。
[root@k8s-master ~]# kubectl get deployments. -n kube-system kubernetes-dashboard -o widename ready up-to-date available age containers images selectorkubernetes-dashboard 1/1 1 1 20m kubernetes-dashboard k8s.gcr.io/kubernetes-dashboard-amd64:v1.10.1 k8s-app=kubernetes-dashboard[root@k8s-master ~]# kubectl get service -n kube-system kubernetes-dashboard name type cluster-ip external-ip port(s) agekubernetes-dashboard clusterip 10.108.187.212 <none> 443/tcp 22m因为 service 是 clusterip 类型,为了方便使用,我们可通过 kubectl –namespace=kube-system edit service kubernetes-dashboard 修改成 nodeport 类型。
spec: clusterip: 10.108.187.212 externaltrafficpolicy: cluster ports: - nodeport: 30338 port: 443 protocol: tcp targetport: 8443 selector: k8s-app: kubernetes-dashboard sessionaffinity: none type: nodeportstatus: loadbalancer: {}保存修改,此时已经为 service 分配了端口 30338。
[root@k8s-master ~]# kubectl get service -n kube-system kubernetes-dashboard name type cluster-ip external-ip port(s) agekubernetes-dashboard nodeport 10.108.187.212 <none> 443:30338/tcp 28m通过浏览器访问 dashboard https://192.168.31.200:30338/,登录界面如下:
配置登录权限
dashboard 支持 kubeconfig 和 token 两种认证方式,为了简化配置,我们通过配置文件 dashboard-admin.yaml 为 dashboard 默认用户赋予 admin 权限。
执行 kubectl apply 使之生效。
现在直接点击登录页面的 skip 就可以进入 dashboard 了。
dashboard的使用
dashboard 界面结构
dashboard 的界面很简洁,分为三个大的区域。
顶部操作区
在这里用户可以搜索集群中的资源、创建资源或退出。
左边导航菜单
通过导航菜单可以查看和管理集群中的各种资源。菜单项按照资源的层级分为两类:
cluster 级别的资源
namespace 级别的资源
默认显示的是 default namespace,可以进行切换:
中间主体区
在导航菜单中点击了某类资源,中间主体区就会显示该资源所有实例,比如点击 pods。
典型使用场景
接下来我们介绍几个 dashboard 的典型使用场景。
部署 deployment
点击顶部操作区的 create 按钮。
用户可以直接输入要部署应用的名字、镜像、副本数等信息;也可以上传 yaml 配置文件。如果是上传配置文件,则可以创建任意类型的资源,不仅仅是 deployment。
在线操作
对于每种资源,都可以点击 按钮执行各种操作。
比如点击 view/edit yaml 可直接修改资源的配置,保存后立即生效,其效果与 kubectl edit 一样。
查看资源详细信息
点击某个资源实例的名字,可以查看到详细信息,其效果与 kubectl describe 一样。
查看 pod 日志
在 pod 及其父资源(daemonset、replicaset 等)页面点击 按钮,可以查看 pod 的日志,其效果与 kubectl logs 一样。
kubernetes dashboard 界面设计友好,自解释性强,可以看作 gui 版的 kubectl。
小结
本章介绍了kubernetes dashboard 的安装和使用方法。dashboard能完成日常管理的大部分工作,可以作为命令行工具 kubectl 的补充。
百度云服务器切换网络节点如何用Notepad 录制宏服务器直接打不开网站了-云服务器问题你们主机怎么购买-备案平台网站上传到虚拟主机的那个文件【黄山seo】怎么做好网站内容的优化帮忙看下本次备案是哪天几点提交到管局的这家备案法人证是最新的-备案平台