部署 Kubernetes 的 Web 管理界面——基于 K8s 部署-爱代码爱编程
部署 Kubernetes 的 Web 管理界面
准备工作:
- 如果未部署 Kubernetes 容器集群管理系统需看:部署 Kubernetes 容器集群管理系统 来进行部署。
- 该实验所需软件包从这个链接下载:https://pan.baidu.com/s/1hpFGyrZBPT7F7EStL7qQaw
- 提取码:xfhh
一、部署 Kubernetes Dashboard web 界面
Kubernetes Dashboard(仪表盘)是一个旨在将通用的基于Web的监控和操作界面加入 Kubernetes 的项目。
1.创建 dashboard-deployment.yaml 配置文件
在 master 上操作
[root@master ~]# vim /etc/kubernetes/dashboard-deployment.yaml
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: kubernetes-dashboard-latest
namespace: kube-system
spec:
replicas: 1
template:
metadata:
labels:
k8s-app: kubernetes-dashboard
version: latest
kubernetes.io/cluster-service: "true"
spec:
containers:
- name: kubernetes-dashboard
image: docker.io/bestwu/kubernetes-dashboard-amd64:v1.6.3
imagePullPolicy: IfNotPresent
resources:
limits:
cpu: 100m
memory: 50Mi
requests:
cpu: 100m
memory: 50Mi
ports:
- containerPort: 9090
args:
- --apiserver-host=http://192.168.1.1:8080
livenessProbe:
httpGet:
path: /
port: 9090
initialDelaySeconds: 30
timeoutSeconds: 30
2.创建 dashboard-service.yaml 配置文件
在 master 上操作
[root@master ~]# vim /etc/kubernetes/dashboard-service.yaml
apiVersion: v1
kind: Service
metadata:
name: kubernetes-dashboard
namespace: kube-system
labels:
k8s-app: kubernetes-dashboard
kubernetes.io/cluster-service: "true"
spec:
selector:
k8s-app: kubernetes-dashboard
ports:
- port: 80
targetPort: 9090
service 的三种端口:
- port:service 暴露在 cluster ip 上的端口,port 是提供给集群内部客户访问 service 的入口。
- nodePort:nodePort 是 k8s 提供给集群外部客户访问 service 入口的一种方式。
- targetPort:targetPort 是 pod 中容器实例上的端口,从 port 和 nodePort 上到来的数据最终经过 kube-proxy 流入到后端 pod 的 targetPort 上进入容器。
总结:
- port 和 nodePort 都是 service 的端口,前者暴露给集群内客户访问服务,后者暴露给集群外客户访问服务。从这两个端口来到的数据都需要经过反向代理 kube-proxy 流入后端 pod 的 targetPod,从而到达 pod 上的容器内。
3.准备 Kubernetes 相关的镜像
node1,node2操作一致
[root@node1 ~]# mkdir /root/k8s
[root@node1 ~]# cd /root/k8s
[root@node1 k8s]# ls
[root@node1 k8s]# ls
docker.io-bestwu-kubernetes-dashboard-amd64-zh.tar pod-infrastructure.tar #将这两个软件包上传到该目录
[root@node1 k8s]# docker load -i pod-infrastructure.tar
[root@node1 k8s]# docker load -i docker.io-bestwu-kubernetes-dashboard-amd64-zh.tar
4.启动 dashboard 的 deployment 和 service
在 master 上操作
[root@master ~]# kubectl create -f /etc/kubernetes/dashboard-deployment.yaml
[root@master ~]# kubectl create -f /etc/kubernetes/dashboard-service.yaml
查看运行结果
[root@master ~]# kubectl get deployment --all-namespaces
[root@master ~]# kubectl get svc --all-namespaces
[root@master ~]# kubectl get pod -o wide --all-namespaces
查看日志
[root@master ~]# kubectl get pod -n kube-system -o wide
[root@master ~]# kubectl logs kubernetes-dashboard-latest-2915596453-m9wpz -n kube-system
5.查看 Kubernetes dashboard web 界面
使用谷歌浏览器访问:http://192.168.1.1:8080/ui
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接: https://blog.csdn.net/weixin_46902396/article/details/111084486