视频教程连接:kubernetes快速入门
前面的kubernets系列文章介绍了通过命令行和yaml文件的方式对kubernetes中资源的管理,命令行和yaml文件方式管理对于管理员来说无疑是利器,而对于普通大众来说,图形管理界面需求则为更迫切的方式,本章介绍kubernetes社区提供的一个图形界面管理工具:kubernetes-dashboard,通过一个WebUI管理kubernetes的资源。
kubernetes中管理集群中资源的方式通常有四种:命令行、YAML、API和图形界面,四种不同的方式适用于不同的人群和场景,对比如下:
社区提供了kubernetes-dashbaord的YAML资源定义文件,直接下载YAML文件安装即可实现dashboard的安装接入,需要准备条件如下:
1、下载kubernetes-dashboard安装文件并应用YAML资源定义
[root@node-1 ~]# kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/v2.0.0-beta8/aio/deploy/recommended.yaml
namespace/kubernetes-dashboard created
serviceaccount/kubernetes-dashboard created
service/kubernetes-dashboard created
secret/kubernetes-dashboard-certs created
secret/kubernetes-dashboard-csrf created
secret/kubernetes-dashboard-key-holder created
configmap/kubernetes-dashboard-settings created
role.rbac.authorization.k8s.io/kubernetes-dashboard created
clusterrole.rbac.authorization.k8s.io/kubernetes-dashboard configured
rolebinding.rbac.authorization.k8s.io/kubernetes-dashboard created
clusterrolebinding.rbac.authorization.k8s.io/kubernetes-dashboard unchanged
deployment.apps/kubernetes-dashboard created
service/dashboard-metrics-scraper created
deployment.apps/dashboard-metrics-scraper created
安装文件中定义了dashboard相关的资源,可以查阅YAML文件,资源包含有:
2、校验资源的安装情况,kubernetes-dashbaord的资源都安装在kubernetes-dashboard命名空间下,包含有Deployments,Services,Secrets,ConfigMap等
3、kubernetes-dashbaord安装完毕后,kubernetes-dashboard默认service的类型为ClusterIP,为了从外部访问控制面板,开放为NodePort类型
4、此时通过https协议访问30433端口即可打开dashboard的控制台,为了保护数据安全性,集群默认开启了RBAC认证授权,需要授予权限的用户才可以访问到kubernetes集群,因此需要授权用户访问集群,集群中已定有了cluster-admin的角色和相关的Role,ClusterRole和ClusterRoleBinding角色,定义ServiceAccount将其关联即可,如下:
[root@node-1 ~]# cat dashboard-rbac.yaml
---
apiVersion: v1
kind: ServiceAccount
metadata:
name: happylau
namespace: kubernetes-dashboard
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: happylau
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: cluster-admin
subjects:
- kind: ServiceAccount
name: happylau
namespace: kubernetes-dashboard
5、应用RBAC规则,创建一个happylau的用户,并和cluster-admin的角色关联
[root@node-1 ~]# kubectl apply -f dashboard-rbac.yaml
serviceaccount/happylau created
clusterrolebinding.rbac.authorization.k8s.io/happylau created
[root@node-1 ~]# kubectl get serviceaccounts -n kubernetes-dashboard
NAME SECRETS AGE
default 1 114m
happylau 1 8s
kubernetes-dashboard 1 114m
6、此时通过kubernetes-dashboard-csrf服务会自动创建一个和用户名关联的Secrets,通过token字段来登陆,token通过base64加密,解密后即可登录,如下演示登录的过程
自此,kubernetes-dashboard安装完毕,通过RBAC认证授权特定用户访问集群权限,接下来一起探索dashboard带来的魔力吧。
kubernetes-dashboard图形工具能提供以下功能:
1、查看集群整体概览资源,可以看到整体集群,应用负载,Pod资源的资源使用情况
2、Cluster集群资源管理,包含还有Nodes,Namespace,StorageClass等,提供在线编辑yaml方式
3、查看应用工作负载Workloads,包含各种不同的工作负载如Deployments,StatefulSets,Jobs等
4、部署Deployments工作负载,支持从YAML文件输入,YAML文件加载和图形界面部署应用
5、工作负载管理,扩展工作负载副本数目,滚动更新等
6、远程登录容器和查看容器日志
kubernetes-dashboard提供了原生的k8s管理工具,提供一个便捷的可视化界面,方便使用控制台管理k8s资源,dashboard提供的功能相对原生,企业可以根据公司的需求通过api进行二次开发,以满足需求。对于k8s管理员而言,一般以使用命令行或yaml文件为主。
dashboard安装手册:https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/
RBAC认证授权:https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/
当你的才华撑不起你的野心时,你就应该静下心来学习
如果觉得文章对您有帮助,请订阅专栏,分享给有需要的朋友吧😊
关于作者 刘海平(HappyLau )云计算高级顾问 目前在腾讯云从事公有云相关工作,曾就职于酷狗,EasyStack,拥有多年公有云+私有云计算架构设计,运维,交付相关经验,参与了酷狗,南方电网,国泰君安等大型私有云平台建设,精通Linux,Kubernetes,OpenStack,Ceph等开源技术,在云计算领域具有丰富实战经验,拥有红帽RHCA/RHCE和OpenStack/Linux授课经验
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。