828华为云征文 | 使用Flexus云服务器X实例部署Kubernetes图形化管理平台

828华为云征文 | 使用Flexus云服务器X实例部署Kubernetes图形化管理平台

  • [1. 基础部署环境说明](#1. 基础部署环境说明)
  • [2. 部署Kubernetes环境](#2. 部署Kubernetes环境)
  • [3. 部署Kubernetes Dashboard](#3. 部署Kubernetes Dashboard)
  • [4. 创建登录账号token](#4. 创建登录账号token)
  • [5. 访问Kubernetes Dashboard](#5. 访问Kubernetes Dashboard)

1. 基础部署环境说明

Kubernetes作为当今最流行的容器编排平台,随着云计算、微服务架构和DevOps文化的普及,Kubernetes在自动化部署、扩展和管理容器化应用程序方面扮演着越来越重要的角色。未来Kubernetes将继续优化其稳定性、安全性和易用性,以满足企业级应用的需求。同时随着边缘计算、AI和大数据等技术的融合,Kubernetes有望成为支撑下一代分布式应用的基础设施,推动整个IT行业的创新与发展。

本次选择使用华为Flexus云服务器X实例部署Kubernetes图形化管理平台,因为最近华为云828 B2B企业节正在举办,选择Flexus X云主机实例,享受定制化性能优化、99.99%的高可用性保障,以及全面的技术支持,让您的业务飞速发展,云端无忧!

2. 部署Kubernetes环境

因为本次主要是在Flexus云服务器X实例中部署Kubernetes图形化管理平台,所以Kubernetes环境的部署不是本篇的重点内容,但是Kubernetes图形化管理平台又依赖Kubernetes环境,所以本次使用kk工具进行Kubernetes环境的部署。当然如果自己有Kubernetes环境,也可以跳过本章节,直接进行下面的部署过程。

javascript 复制代码
[root@flexusx-3e9a ~]# export KKZONE=cn
[root@flexusx-3e9a ~]# curl -sfL https://get-kk.kubesphere.io | VERSION=v2.3.0 sh -

[root@flexusx-3e9a ~]# tar xvf kubekey-v2.3.0-linux-amd64.tar.gz
[root@flexusx-3e9a ~]# ./kk version --show-supported-k8s
v1.19.0
v1.19.8
v1.19.9
v1.20.4
v1.20.6
v1.20.10
v1.21.0
v1.21.1
......

[root@flexusx-3e9a ~]# ./kk create cluster --with-kubernetes v1.22.12 

3. 部署Kubernetes Dashboard

部署和访问Kubernetes Dashboard官方手册

javascript 复制代码
[root@flexusx-3e9a ~]# wget https://raw.githubusercontent.com/kubernetes/dashboard/v2.7.0/aio/deploy/recommended.yaml

[root@flexusx-3e9a ~]# grep image recommended.yaml
          image: registry.cn-hangzhou.aliyuncs.com/cloud_wzy/dashboard:v2.7.0
          imagePullPolicy: IfNotPresent
          image: registry.cn-hangzhou.aliyuncs.com/cloud_wzy/metrics-scraper:v1.0.8
javascript 复制代码
[root@flexusx-3e9a ~]# kubectl apply -f recommended.yaml
javascript 复制代码
[root@flexusx-3e9a ~]# kubectl get ns
NAME                   STATUS   AGE
kubernetes-dashboard   Active   21s

[root@flexusx-3e9a ~]# kubectl get pods -n kubernetes-dashboard
NAME                                        READY   STATUS    RESTARTS   AGE
dashboard-metrics-scraper-66fbb549b-g9n2j   1/1     Running   0          47s
kubernetes-dashboard-67c5c7dc6b-fqpnv       1/1     Running   0          47s
javascript 复制代码
[root@flexusx-3e9a ~]# kubectl get svc -n kubernetes-dashboard
NAME                        TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)    AGE
dashboard-metrics-scraper   ClusterIP   10.102.209.140   <none>        8000/TCP   2m12s
kubernetes-dashboard        ClusterIP   10.101.169.76    <none>        443/TCP    2m12s


[root@flexusx-3e9a ~]# kubectl edit svc kubernetes-dashboard -n kubernetes-dashboard
......
  selector:
    k8s-app: kubernetes-dashboard
  sessionAffinity: None
  type: NodePort


[root@flexusx-3e9a ~]# kubectl get svc -n kubernetes-dashboard
NAME                        TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)         AGE
dashboard-metrics-scraper   ClusterIP   10.102.209.140   <none>        8000/TCP        8m49s
kubernetes-dashboard        NodePort    10.101.169.76    <none>        443:30156/TCP   8m49s

4. 创建登录账号token

创建SA(此SA账号用于和集群内的程序交互使用,可以参考我的其他博客了解SA账号作用):

javascript 复制代码
[root@flexusx-3e9a ~]# kubectl create sa dashboardsa -n kube-system
[root@flexusx-3e9a ~]# kubectl get sa -n kube-system | grep dashboardsa
dashboardsa                          0         57s

[root@flexusx-3e9a ~]# kubectl create clusterrolebinding rolebind-dashboard --clusterrole admin --serviceaccount kube-system:dashboardsa -n kube-system

因为从kubernetes 1.24版本开始,创建SA不再自动生成secrets,所以接下来需要手动创建一个secrets

手动创建secrets:官方参考手册

javascript 复制代码
[root@flexusx-3e9a ~]# vim dashboardsa-secret.yaml
[root@flexusx-3e9a ~]# cat dashboardsa-secret.yaml
apiVersion: v1
kind: Secret
metadata:
  name: secret-sa-sample
  annotations:
    kubernetes.io/service-account.name: "dashboardsa"
type: kubernetes.io/service-account-token
javascript 复制代码
[root@flexusx-3e9a ~]# kubectl apply -f dashboardsa-secret.yaml -n kube-system
[root@flexusx-3e9a ~]# kubectl get secrets -n kube-system
NAME               TYPE                                  DATA   AGE
secret-sa-sample   kubernetes.io/service-account-token   3      12s

[root@flexusx-3e9a ~]# kubens kube-system
[root@flexusx-3e9a ~]# kubectl describe secrets secret-sa-sample
Name:         secret-sa-sample
Namespace:    kube-system
Labels:       <none>
Annotations:  kubernetes.io/service-account.name: dashboardsa
              kubernetes.io/service-account.uid: 90bc6cea-5b6e-4a14-b271-3e3f26cb87a4

Type:  kubernetes.io/service-account-token

Data
====
ca.crt:     1099 bytes
namespace:  11 bytes
token:      eyJhbGciOiJSUzI1NiIsImtpZCI6IlJ5WnAtellKaHF2VWxpc0FvRTNoc2JTRkZFQ2VnY09SX1FlNjRDTTZjSmMifQ.eyJpc3MiOiJrdWJlcm5ldGVzL3NlcnZpY2VhY2NvdW50Iiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9uYW1lc3BhY2UiOiJrdWJlLXN5c3RlbSIsImt1YmVybmV0ZXMuaW8vc2VydmljZWFjY291bnQvc2VjcmV0Lm5hbWUiOiJzZWNyZXQtc2Etc2FtcGxlIiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9zZXJ2aWNlLWFjY291bnQubmFtZSI6ImRhc2hib2FyZHNhIiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9zZXJ2aWNlLWFjY291bnQudWlkIjoiOTBiYzZjZWEtNWI2ZS00YTE0LWIyNzEtM2UzZjI2Y2I4N2E0Iiwic3ViIjoic3lzdGVtOnNlcnZpY2VhY2NvdW50Omt1YmUtc3lzdGVtOmRhc2hib2FyZHNhIn0.rbqlQuYMx6YqAo0GOhMKbNkTRjGUkWOOfyndaQCqHzZckpxFUK5YRvvN88k5-DFA0L0nHBWx1LBijINgEKig9wsaB1VOU5tAsoDRdR5PSTeGrp6H5urVXVHQ5tTwug8G2P8BgDzu0eYGvihpEh27Ovt4H-CNmvfgvTIvlJ3rIopsierDhhtC2L0HyLtZK0b2__o4cbErcFGCmca6TVLMbOH__jCDtO4v80dKXN0VKevozc_l1aQ0KD-UGehpsE7nch2fx1IALyNLXbIlgUflTzXOvFyiNysiSXlzBQUITGLW37Htfqw9k2MaSfPTnHA1yn-ly4jKjWx5L0dQ1_UZdQ

5. 访问Kubernetes Dashboard

也可以选择使用Kubeconfig方式登录,将kubernetes集群中/etc/kubernetes/admin.conf文件下载到本地,然后再上传到此处即可。

javascript 复制代码
[root@flexusx-3e9a ~]# kubectl get deployment -n demo
NAME           READY   UP-TO-DATE   AVAILABLE   AGE
wzy-demo2024   5/5     5            5           62m


[root@flexusx-3e9a ~]# kubectl get pod -n demo
NAME                            READY   STATUS    RESTARTS   AGE
wzy-demo2024-5c757c7bc4-6655c   1/1     Running   0          62m
wzy-demo2024-5c757c7bc4-j8ngd   1/1     Running   0          62m
wzy-demo2024-5c757c7bc4-pp68q   1/1     Running   0          62m
wzy-demo2024-5c757c7bc4-rcqmt   1/1     Running   0          62m
wzy-demo2024-5c757c7bc4-tw598   1/1     Running   0          62m

[root@flexusx-3e9a ~]# kubectl get svc -n demo
NAME           TYPE           CLUSTER-IP     EXTERNAL-IP      PORT(S)        AGE
wzy-demo2024   LoadBalancer   10.98.123.58   192.168.24.237   80:31810/TCP   62m
相关推荐
lihuhelihu32 分钟前
第3章 CentOS系统管理
linux·运维·服务器·计算机网络·ubuntu·centos·云计算
YCyjs35 分钟前
K8S群集调度二
云原生·容器·kubernetes
Hoxy.R36 分钟前
K8s小白入门
云原生·容器·kubernetes
山东布谷科技官方1 小时前
布谷直播源码部署服务器关于数据库配置的详细说明
运维·服务器·数据库·直播系统源码·直播源码·直播系统搭建·直播软件开发
爱吃喵的鲤鱼1 小时前
linux进程的状态之环境变量
linux·运维·服务器·开发语言·c++
荒Huang2 小时前
Linux挖矿病毒(kswapd0进程使cpu爆满)
linux·运维·服务器
九河云3 小时前
如何选择适合的AWS EC2实例类型
服务器·云计算·aws
其乐无涯4 小时前
服务器技术(一)--Linux基础入门
linux·运维·服务器
写bug的小屁孩4 小时前
前后端交互接口(三)
运维·服务器·数据库·windows·用户界面·qt6.3
斑布斑布4 小时前
【linux学习2】linux基本命令行操作总结
linux·运维·服务器·学习