k8s-03-3-安装dashboard
kubernetes-dashboard简介kubernetes中管理集群中资源的方式通常有四种:命令行、YAML、API和图形界面,四种不同的方式适用于不同的人群和场景,对比如下:命令行kubectl,kubectl提供了命令行管理kubernetes资源优点:使用方便、便捷、快速管理集群资源缺点:功能相对有限,部分操作无法支持,有一定的门槛YAML资源定义,kubernetes中最终转换形式,
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
kubernetes-dashboard安装
1、下载kubernetes-dashboard安装文件并应用YAML资源定义 【https://github.com/kubernetes/dashboard】*失败的话多试几次
kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/v2.0.4/aio/deploy/recommended.yaml
安装文件中定义了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等
kubectl get deployments -n kubernetes-dashboard
kubectl get services -n kubernetes-dashboard
kubectl get secrets -n kubernetes-dashboard
kubectl get configMap -n kubernetes-dashboard
3、kubernetes-dashbaord安装完毕后,kubernetes-dashboard默认service的类型为ClusterIP,为了从外部访问控制面板,开放为NodePort类型
kubectl get services -n kubernetes-dashboard
# ClusterIP-->NodePord
kubectl edit services -n kubernetes-dashboard kubernetes-dashboard
or
kubectl -n kubernetes-dashboard patch services kubernetes-dashboard -p '{"spec":{"type":"NodePort"}}'
访问地址:https://192.168.44.129:30953/
token(令牌)方式认证
# 创建token
kubectl -n kubernetes-dashboard create token kubernetes-dashboard
#查看权限
#'因为token只是创建了,但是没有放在secrets里'
kubectl -n kubernetes-dashboard get serviceaccounts kubernetes-dashboard
#集群管理员有所有权限
kubectl -n kubernetes-dashboard describe clusterrole cluster-admin
#授权 '集群角色绑定(kubernetes-dashboard-cluster-admin名称任意)'
kubectl create clusterrolebinding kubernetes-dashboard-cluster-admin --clusterrole=cluster-admin --serviceaccount=kubernetes-dashboard:kubernetes-dashboard
#查看集群的权限绑定
$ kubectl get clusterrolebindings -o wide | grep dash
kubeconfig 方式认证
把 serviceaccount 的token 封装为 kubeconfig 文件
6、此时通过kubernetes-dashboard-csrf服务会自动创建一个和用户名关联的Secrets,通过token字段来登陆,token通过base64加密,解密后即可登录
修改默认token认证过期时间
kubernetes-dashboard默认900s/15分钟后认证token回话失效,需要重新登录认证(太麻烦),可以修改下(24H)
方法1:
kubectl edit deployment kubernetes-dashboard -n kubernetes-dashboard
方法2
修改新增 --token-ttl=43200
探索kubernetes-dashboard
kubernetes-dashboard提供了原生的k8s管理工具,提供一个便捷的可视化界面,方便使用控制台管理k8s资源,dashboard提供的功能相对原生,企业可以根据公司的需求通过api进行二次开发,以满足需求。对于k8s管理员而言,一般以使用命令行或yaml文件为主。
更多推荐
所有评论(0)