目录

1.准备dashboard镜像

2.创建资源配置清单

3.应用资源配置清单

4.查看创建的资源

5.解析域名

6.浏览器访问

7.令牌命令行获取方式

准备dashboard镜像

  1. [root@hdss7-200 k8s-yaml]# docker pull k8scn/kubernetes-dashboard-amd64:v1.8.3
  2. [root@hdss7-200 k8s-yaml]# docker images|grep dashboard
  3. [root@hdss7-200 k8s-yaml]# docker tag fcac9aa03fd6 harbor.fx.com/public/dashboard:v1.8.3
  4. [root@hdss7-200 k8s-yaml]# docker push harbor.fx.com/public/dashboard:v1.8.3

创建资源配置清单

  1. [root@hdss7-200 k8s-yaml]# mkdir -p /data/k8s-yaml/dashboard && cd /data/k8s-yaml/dashboard

rabc.yaml

  1. [root@hdss7-200 dashboard]# vim rbac.yaml
  2. apiVersion: v1
  3. kind: ServiceAccount
  4. metadata:
  5. labels:
  6. k8s-app: kubernetes-dashboard
  7. addonmanager.kubernetes.io/mode: Reconcile
  8. name: kubernetes-dashboard-admin
  9. namespace: kube-system
  10. ---
  11. apiVersion: rbac.authorization.k8s.io/v1
  12. kind: ClusterRoleBinding
  13. metadata:
  14. name: kubernetes-dashboard-admin
  15. namespace: kube-system
  16. labels:
  17. k8s-app: kubernetes-dashboard
  18. addonmanager.kubernetes.io/mode: Reconcile
  19. roleRef:
  20. apiGroup: rbac.authorization.k8s.io
  21. kind: ClusterRole
  22. name: cluster-admin
  23. subjects:
  24. - kind: ServiceAccount
  25. name: kubernetes-dashboard-admin
  26. namespace: kube-system

dp.yaml

  1. [root@hdss7-200 dashboard]# vi dp.yaml
  2. apiVersion: apps/v1
  3. kind: Deployment
  4. metadata:
  5. name: kubernetes-dashboard
  6. namespace: kube-system
  7. labels:
  8. k8s-app: kubernetes-dashboard
  9. kubernetes.io/cluster-service: "true"
  10. addonmanager.kubernetes.io/mode: Reconcile
  11. spec:
  12. selector:
  13. matchLabels:
  14. k8s-app: kubernetes-dashboard
  15. template:
  16. metadata:
  17. labels:
  18. k8s-app: kubernetes-dashboard
  19. annotations:
  20. scheduler.alpha.kubernetes.io/critical-pod: ''
  21. spec:
  22. priorityClassName: system-cluster-critical
  23. containers:
  24. - name: kubernetes-dashboard
  25. image: harbor.fx.com/public/dashboard:v1.8.3
  26. resources:
  27. limits:
  28. cpu: 100m
  29. memory: 300Mi
  30. requests:
  31. cpu: 50m
  32. memory: 100Mi
  33. ports:
  34. - containerPort: 8443
  35. protocol: TCP
  36. args:
  37. # PLATFORM-SPECIFIC ARGS HERE
  38. - --auto-generate-certificates
  39. volumeMounts:
  40. - name: tmp-volume
  41. mountPath: /tmp
  42. livenessProbe:
  43. httpGet:
  44. scheme: HTTPS
  45. path: /
  46. port: 8443
  47. initialDelaySeconds: 30
  48. timeoutSeconds: 30
  49. volumes:
  50. - name: tmp-volume
  51. emptyDir: {}
  52. serviceAccountName: kubernetes-dashboard-admin
  53. tolerations:
  54. - key: "CriticalAddonsOnly"
  55. operator: "Exists"

svc.yaml

  1. [root@hdss7-200 dashboard]# vim svc.yaml
  2. apiVersion: v1
  3. kind: Service
  4. metadata:
  5. name: kubernetes-dashboard
  6. namespace: kube-system
  7. labels:
  8. k8s-app: kubernetes-dashboard
  9. kubernetes.io/cluster-service: "true"
  10. addonmanager.kubernetes.io/mode: Reconcile
  11. spec:
  12. selector:
  13. k8s-app: kubernetes-dashboard
  14. ports:
  15. - port: 443
  16. targetPort: 8443

ingress.yaml

  1. [root@hdss7-200 dashboard]# vim ingress.yaml
  2. apiVersion: extensions/v1beta1
  3. kind: Ingress
  4. metadata:
  5. name: kubernetes-dashboard
  6. namespace: kube-system
  7. annotations:
  8. kubernetes.io/ingress.class: traefik
  9. spec:
  10. rules:
  11. - host: dashboard.fx.com
  12. http:
  13. paths:
  14. - backend:
  15. serviceName: kubernetes-dashboard
  16. servicePort: 443

应用资源配置清单

  1. [root@hdss7-21 ~]# kubectl apply -f http://k8s-yaml.fx.com/dashboard/rbac.yaml
  2. [root@hdss7-21 ~]# kubectl apply -f http://k8s-yaml.fx.com/dashboard/dp.yaml
  3. [root@hdss7-21 ~]# kubectl apply -f http://k8s-yaml.fx.com/dashboard/svc.yaml
  4. [root@hdss7-21 ~]# kubectl apply -f http://k8s-yaml.fx.com/dashboard/ingress.yaml

查看创建的资源

  1. [root@hdss7-21 ~]# kubectl get pods -n kube-system
  2. [root@hdss7-21 ~]# kubectl get svc -n kube-system
  3. [root@hdss7-21 ~]# kubectl get ingress -n kube-system

解析域名

  1. [root@hdss7-11 ~]# vim /var/named/fx.com.zone
  2. $ORIGIN fx.com.
  3. $TTL 600 ; 10 minutes
  4. @ IN SOA dns.fx.com. dnsadmin.fx.com. (
  5. 2020061010 ; serial
  6. 10800 ; refresh (3 hours)
  7. 900 ; retry (15 minutes)
  8. 604800 ; expire (1 week)
  9. 86400 ; minimum (1 day)
  10. )
  11. NS dns.fx.com.
  12. $TTL 60 ; 1 minute
  13. dns A 10.4.7.11
  14. harbor A 10.4.7.200
  15. k8s-yaml A 10.4.7.200
  16. traefik A 10.4.7.10
  17. dashboard A 10.4.7.10
  18. [root@hdss7-11 ~]# systemctl restart named

浏览器访问

  1. http://dashboard.fx.com/

 创建dashboard证书

  1. [root@hdss7- certs]# (umask ; openssl genrsa -out dashboard.fx.com.key )
  2. [root@hdss7- certs]# openssl req -new -key dashboard.fx.com.key -out dashboard.fx.com.csr -subj "/CN=dashboard.fx.com/C=CN/ST=BJ/L=Beijing/O=fangxing/OU=ops"
  3. [root@hdss7- certs]# openssl x509 -req -in dashboard.fx.com.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out dashboard.fx.com.crt -days

拷贝证书

在HDSS7-11.host.com上

  1. [root@hdss7- conf.d]# mkdir -p /etc/nginx/certs && cd /etc/nginx/certs
  2. [root@hdss7- certs]# scp hdss7-:/opt/certs/dashboard.fx.com.crt .
  3. [root@hdss7- certs]# scp hdss7-:/opt/certs/dashboard.fx.com.key .

注:HDSS7-12.host.com也需要copy证书

配置nginx证书

在HDSS7-11.host.com上

  1. [root@hdss7- conf.d]# vim dashboard.fx.com.conf
  2. server {
  3. listen ;
  4. server_name dashboard.fx.com;
  5.  
  6. rewrite ^(.*)$ https://${server_name}$1 permanent;
  7. }
  8. server {
  9. listen ssl;
  10. server_name dashboard.fx.com;
  11.  
  12. ssl_certificate "certs/dashboard.fx.com.crt";
  13. ssl_certificate_key "certs/dashboard.fx.com.key";
  14. ssl_session_cache shared:SSL:1m;
  15. ssl_session_timeout 10m;
  16. ssl_ciphers HIGH:!aNULL:!MD5;
  17. ssl_prefer_server_ciphers on;
  18.  
  19. location / {
  20. proxy_pass http://default_backend_traefik;
  21. proxy_set_header Host $http_host;
  22. proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for;
  23. }
  24. }

注:HDSS7-12.host.com也需要配置nginx

令牌命令行获取方式

  1. [root@hdss7-21 ~]# kubectl get secret -n kube-system
  2. [root@hdss7-21 ~]# kubectl describe secret kubernetes-dashboard-admin-token-c8gsp -n kube-system
  3. Name: kubernetes-dashboard-admin-token-c8gsp
  4. Namespace: kube-system
  5. Labels: <none>
  6. Annotations: kubernetes.io/service-account.name: kubernetes-dashboard-admin
  7. kubernetes.io/service-account.uid: 22e7c7e4-8c03-4dad-a942-2a00a6689d14
  8.  
  9. Type: kubernetes.io/service-account-token
  10.  
  11. Data
  12. ====
  13. token: eyJhbGciOiJSUzI1NiIsImtpZCI6IiJ9.eyJpc3MiOiJrdWJlcm5ldGVzL3NlcnZpY2VhY2NvdW50Iiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9uYW1lc3BhY2UiOiJrdWJlLXN5c3RlbSIsImt1YmVybmV0ZXMuaW8vc2VydmljZWFjY291bnQvc2VjcmV0Lm5hbWUiOiJrdWJlcm5ldGVzLWRhc2hib2FyZC1hZG1pbi10b2tlbi1jOGdzcCIsImt1YmVybmV0ZXMuaW8vc2VydmljZWFjY291bnQvc2VydmljZS1hY2NvdW50Lm5hbWUiOiJrdWJlcm5ldGVzLWRhc2hib2FyZC1hZG1pbiIsImt1YmVybmV0ZXMuaW8vc2VydmljZWFjY291bnQvc2VydmljZS1hY2NvdW50LnVpZCI6IjIyZTdjN2U0LThjMDMtNGRhZC1hOTQyLTJhMDBhNjY4OWQxNCIsInN1YiI6InN5c3RlbTpzZXJ2aWNlYWNjb3VudDprdWJlLXN5c3RlbTprdWJlcm5ldGVzLWRhc2hib2FyZC1hZG1pbiJ9.eM2aJ7L9amwdo6XHYT2S5w6FMTdsu8u6hmB5bAcLrDJPwdiNMevriF9LensNtdobZlUd10qTmJ_uVDl7W_pW7sycN1MYpSyre7FPMiwaH8bSpcwCibgMSoCA5ce9eShePJ14iErBD12h1ru0BI1O-Vk-WC9yfBdrbBG4e9R3YclaKCo38Y7wS2WgMi0intELPyG-Sb8s3BTpPdnFBN5I_FAFtmAmonpuAz17FpxrMxF7ZlJXxhPwY1GoAHkKDkvw3J3z6peEGAazqZup-N4b6cjAyIucLd4xNbUXviAP6lGDGFAaHF7E-oN2Ec8WWNm3M26m2I3zxb_fyl8v9lNacQ
  14. ca.crt: 1342 bytes
  15. namespace: 11 bytes

注:令牌对应的是token

验证令牌登录

部署heapster

  1. [root@hdss7- dashboard]# mkdir heapster
  2. [root@hdss7- heapster]# docker pull quay.io/bitnami/heapster:1.5.
  3. [root@hdss7- heapster]# docker tag c359b95ad38b harbor.fx.com/public/heapster:v1.5.4
  4. [root@hdss7- heapster]# docker push harbor.fx.com/public/heapster:v1.5.4

应用heapster配置清单

  1. [root@hdss7- ~]# kubectl apply -f http://k8s-yaml.fx.com/dashboard/heapster/rbac.yaml
  2. [root@hdss7- ~]# kubectl apply -f http://k8s-yaml.fx.com/dashboard/heapster/deployment.yaml
  3. [root@hdss7- ~]# kubectl apply -f http://k8s-yaml.fx.com/dashboard/heapster/svc.yaml

重新登录dashboard查看

6.kubernetes的GUI资源管理插件-dashboard的更多相关文章

  1. 第十三章 k8s的GUI资源管理插件--dashboard

    1.部署Kubernetes-dashboard 1.1 准备dashboard镜像 在10.4.7.200上操作 [root@hdss7-200 ~]# docker pull k8scn/kube ...

  2. kubernetes 1.14安装部署dashboard

    简单介绍: Dashboard是一个基于web的Kubernetes用户界面.您可以使用Dashboard将容器化应用程序部署到Kubernetes集群,对容器化应用程序进行故障诊断,并管理集群资源. ...

  3. Kubernetes 部署Web UI (Dashboard)

    Kubernetes 部署Web UI (Dashboard) 项目下载地址:https://github.com/kubernetes/kubernetes/tree/master/cluster/ ...

  4. Kubernetes V1.16.2部署Dashboard V2.0(beta5)

    Kubernetes V1.16.2部署Dashboard V2.0(beta5) 在Master上部署Dashboard 集群安装部署请看安装Kubernetes V1.16.2 kubectl g ...

  5. 第21 章 : Kubernetes 存储架构及插件使用

    Kubernetes 存储架构及插件使用 本文将主要分享以下三方面的内容: Kubernetes 存储体系架构: Flexvolume 介绍及使用: CSI 介绍及使用. Kubernetes 存储体 ...

  6. 第18 章 : Kubernetes 调度和资源管理

    Kubernetes 调度和资源管理 这节课主要讲三部分的内容: Kubernetes 的调度过程: Kubernetes 的基础调度能力(资源调度.关系调度): Kubernetes 高级调度能力( ...

  7. 019.Kubernetes二进制部署插件dashboard

    一 修改配置文件 1.1 下载解压 [root@k8smaster01 ~]# cd /opt/k8s/work/kubernetes/ [root@k8smaster01 kubernetes]# ...

  8. Kubernetes系列之Coredns and Dashboard介绍篇

    本次系列使用的所需部署包版本都使用的目前最新的或最新稳定版,安装包地址请到公众号内回复[K8s实战]获取 介绍 项目地址:https://github.com/coredns/coredns Core ...

  9. kubernetes实战(二十八):Kubernetes一键式资源管理平台Ratel安装及使用

    1. Ratel是什么? Ratel是一个Kubernetes资源平台,基于管理Kubernetes的资源开发,可以管理Kubernetes的Deployment.DaemonSet.Stateful ...

随机推荐

  1. 【Elasticsearch学习】DSL搜索大全(持续更新中)

    1.复合查询 复合查询能够组合其他复合查询或者查询子句,同时也可以组合各个查询的查询结果及得分,也可以从Query查询转换为Filter过滤器查询. 首先介绍一下Query Context和 Filt ...

  2. 永久激活idea

    申明:本教程 IntelliJ IDEA 破解补丁.激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除. idea版本为老版本2018版本,下载地址如下,激活方法和插件在压缩包中 ...

  3. linux:基本指令

    指令标准格式 指令主体 [选项][操作对象] 基础指令 ls 1.ls 列出当前工作目录下的所有文件/文件夹的名称 2.ls  路径 列出指定路径下的所有文件/文件夹的名称 路径: 1.相对路径 会用 ...

  4. 移动端适配-rem(新)

    概念 对于移动端开发来说,无可避免的就是直面各种设备不同分辨率和不同DPR(设备像素比)的问题,在此忽略其他兼容性问题的探讨. 移动端像素 设备像素(dp),也叫物理像素.指设备能控制显示的最小物理单 ...

  5. Java试题错题集01

    1.javac与java命令 两个命令 javac 和 java. javac 后面跟着的是java文件的文件名,例如 HelloWorld.java. 该命令用于将 java 源文件编译为 clas ...

  6. C#/WPF/WinForm/.NET程序代码实现软件程序开机自动启动的两种常用方法的示例与源码下载带详细注释-源码代码-注册表方式-启动目录快捷方式

    C#/WPF/WinForm/.NET程序代码实现软件程序开机自动启动的两种常用方法的示例与源码下载带详细注释-源码代码-注册表方式-启动目录快捷方式 C#实现自动启动的方法-两种方法 源码下载地址: ...

  7. Java实现 蓝桥杯VIP 算法训练 集合运算

    问题描述 给出两个整数集合A.B,求出他们的交集.并集以及B在A中的余集. 输入格式 第一行为一个整数n,表示集合A中的元素个数. 第二行有n个互不相同的用空格隔开的整数,表示集合A中的元素. 第三行 ...

  8. Java实现Catenyms(并查集+dfs+欧拉回路)

    Description A catenym is a pair of words separated by a period such that the last letter of the firs ...

  9. cocos2dx获得字体的宽高

    Android: 1.在CCImage中添加下面的方法: //头文件声明略. cocos2d::CCSize CCImage::getStringSize(const char *text, cons ...

  10. 3.keras-简单实现Mnist数据集分类

    keras-简单实现Mnist数据集分类 1.载入数据以及预处理 import numpy as np from keras.datasets import mnist from keras.util ...