您好,欢迎来到站长目录(28sn.com)!


kubernetes入门到实战(四)dashboard图形界面让k8s更简单

来源:网络整理 浏览:344次 时间:2020-11-29
1. kubernetes-dashboard简介

kubernetes中管理集群中资源的方式通常有四种:命令行、YAML、API和图形界面,四种不同的方式适用于不同的人群和场景,对比如下:

  • 命令行kubectl,kubectl提供了命令行管理kubernetes资源
    • 优点:使用方便、便捷、快速管理集群资源
    • 缺点:功能相对有限,部分操作无法支持,有一定的门槛
  • YAML资源定义,kubernetes中最终转换形式,推荐使用方式
    • 优点:功能齐备,能够定义kubernetes的所有对象和资源
    • 缺点:门槛较高,需要具备专业技术能力,使用排障难度大
  • API管理接入,提供各种编程语言SDK接口,方便各种编程语言应用程序接入
    • 优点:适配各种编程语言,如Java,Go,Python,C等,方便开发kubernetes
    • 缺点:门槛较高,适用于开发人员
  • 图形kubernetes-dashboard,提供图形化管理界面,能够利用metric-server实现node和pod的监控
    • 优点:使用简单,便捷,适合大众。
    • 缺点:功能相对简单,功能原生,适用于demo
2. kubernetes-dashboard安装

社区提供了kubernetes-dashbaord的YAML资源定义文件,直接下载YAML文件安装即可实现dashboard的安装接入,需要准备条件如下:

  • 已安装好的kubernetes集群,本文环境为1.15.3
  • metric-server监控,node监控和pod监控视图需依赖于监控系统
  • RBAC认证授权,设置好账户并授予访问权限

1、下载kubernetes-dashboard安装文件并应用YAML资源定义

[root@node-1 ~]# kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/v2.0.0-beta8/aio/deploy/recommended.yamlnamespace/kubernetes-dashboard createdserviceaccount/kubernetes-dashboard createdservice/kubernetes-dashboard createdsecret/kubernetes-dashboard-certs createdsecret/kubernetes-dashboard-csrf createdsecret/kubernetes-dashboard-key-holder createdconfigmap/kubernetes-dashboard-settings createdrole.rbac.authorization.k8s.io/kubernetes-dashboard createdclusterrole.rbac.authorization.k8s.io/kubernetes-dashboard configuredrolebinding.rbac.authorization.k8s.io/kubernetes-dashboard createdclusterrolebinding.rbac.authorization.k8s.io/kubernetes-dashboard unchangeddeployment.apps/kubernetes-dashboard createdservice/dashboard-metrics-scraper createddeployment.apps/dashboard-metrics-scraper created

安装文件中定义了dashboard相关的资源,可以查阅YAML文件,资源包含有:

  • kubernetes-dashboard命名空间
  • ServiceAccount访问用户
  • Service服务访问应用,默认为ClusterIP
  • Secrets,存放有kubernetes-dashboard-certs,kubernetes-dashboard-csrf,kubernetes-dashboard-key-holder证书
  • ConfigMap配置文件
  • RBAC认证授权,包含有Role,ClusterRole,RoleBinding,ClusterRoleBinding
  • Deployments应用,kubernetes-dashboard核心镜像,还有一个和监控集成的dashboard-metrics-scraper

2、校验资源的安装情况,kubernetes-dashbaord的资源都安装在kubernetes-dashboard命名空间下,包含有Deployments,Services,Secrets,ConfigMap等

kubernetes-dashboard安装校验

3、kubernetes-dashbaord安装完毕后,kubernetes-dashboard默认service的类型为ClusterIP,为了从外部访问控制面板,开放为NodePort类型

修改kubernetes-dashboard service类型

4、此时通过https协议访问30433端口即可打开dashboard的控制台,为了保护数据安全性,集群默认开启了RBAC认证授权,需要授予权限的用户才可以访问到kubernetes集群,因此需要授权用户访问集群,集群中已定有了cluster-admin的角色和相关的Role,ClusterRole和ClusterRoleBinding角色,定义ServiceAccount将其关联即可,如下:

[root@node-1 ~]# cat dashboard-rbac.yaml ---apiVersion: v1kind: ServiceAccountmetadata:  name: happycloudlab   namespace: kubernetes-dashboard---apiVersion: rbac.authorization.k8s.io/v1kind: ClusterRoleBindingmetadata:  name: happycloudlabroleRef:  apiGroup: rbac.authorization.k8s.io  kind: ClusterRole  name: cluster-adminsubjects:- kind: ServiceAccount  name: happylau   namespace: kubernetes-dashboard

5、应用RBAC规则,创建一个happycloudlab的用户,并和cluster-admin的角色关联

[root@node-1 ~]# kubectl apply -f dashboard-rbac.yaml serviceaccount/happycloudlab createdclusterrolebinding.rbac.authorization.k8s.io/happylau created[root@node-1 ~]# kubectl get serviceaccounts -n kubernetes-dashboard NAME                   SECRETS   AGEdefault                1         114mhappylau               1         8skubernetes-dashboard   1         114m

6、此时通过kubernetes-dashboard-csrf服务会自动创建一个和用户名关联的Secrets,通过token字段来登陆,token通过base64加密,解密后即可登录,如下演示登录的过程

kubernetes-dashboard获取token登录

自此,kubernetes-dashboard安装完毕,通过RBAC认证授权特定用户访问集群权限,接下来一起探索dashboard带来的魔力吧。

3. 探索kubernetes-dashboard

kubernetes-dashboard图形工具能提供以下功能:

  • 查看kubernetes中的资源对象,包含kubernetes中各种资源
    • Cluster 集群级别的资源,如命名空间,节点,PV,StorageClass,ClusterRole等
    • Workloads,不同类型的工作负载,包含Deployments,StatefulSets,DaemonSets,Jobs等
    • Discovery and LoadBalancing,服务发现和负载均衡,包含service和ingress
    • ConfigMap and Storage,包含ConfigMap,Secrets和PVC
    • Costom Resource Definition,自定义资源定义
  • kubernetes资源监控,调用metric-server监控系统,实现Cluster集群,Workloads应用负载,存储等资源的监控
  • 管理资源对象,包含创建,编辑yaml,删除负载等,主要是以Deployments等应用为主的管理

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/

推荐站点

  • 我爱发烧音乐我爱发烧音乐

    我爱发烧音乐囊括了从流行音乐到古典音乐多个类型的音乐作品,专栏推荐最新的音乐,提供音乐排名榜单!可供免费线上收听音乐,歌曲流畅,音效极佳! 网站提供的钢琴以及二胡专栏,可供收听者,陶冶情操,改善心情,是难得的轻音乐典藏!

    www.520fs.com
  • 世纪音乐网世纪音乐网

    世纪音乐网是专业的在线音乐试听MP3下载网站。歌曲总计30余万首,收录了网上最新歌曲和流行音乐,DJ舞曲,非主流音乐,经典老歌,劲舞团歌曲,搞笑歌曲,儿童歌曲,英文歌曲等。是您上网听歌的最佳网站。

    www.ssjj.com
  • 怒江大峡谷网怒江大峡谷网

    怒江大峡谷网内容包括:新闻、要闻、怒江报、视频、文化、民俗、人文、音乐、政务、公告、政策等地方信息。

    www.nujiang.cn
  • 杭州网杭州网

      杭州网是杭州地区唯一的新闻门户网站,由中共杭州市委宣传部、杭州日报报业集团和杭州广播电视集团共同组建的杭州网络传媒有限公司运营。

    www.hangzhou.com.cn
  • 深圳在线深圳在线

      深圳在线 www.szol.net是深圳本地最大、最早的地方生活资讯网站之一,网站名“深圳在线www.szol.net”由南方报业传媒集团编辑委员会总编辑、南方日报社总编辑、南方都市报总编辑、南方书画院名誉院长王春芙亲笔题名,深圳在线www.szol.net团队与深圳热线www.szonline.net、奥一网www.oeeee.com都源于全国最早成立于1996年的知名网络公司——深圳万用网。

    www.szol.net

鄂公网安备 42062502000001号