一、windows系统使用kubectl
1、windows安装Chocolatey
参考文章Installing Chocolatey
管理员运行 powershell
Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1'))
data:image/s3,"s3://crabby-images/f524f/f524ff828773440fb825d6c800f6e6ec1bdf1ab2" alt=""
2、安装kubectl
参考文章Kubernetes Command Line Interface (CLI)
1.18.2
choco install kubernetes-cli
data:image/s3,"s3://crabby-images/56d93/56d93744c1517b702e4a3169ab828997ba97de04" alt=""
3、config文件
注意到在之前安装k8s有如下步骤
data:image/s3,"s3://crabby-images/5448f/5448f4d7b29ee63907dee96203f7ff5d802dafa2" alt=""
所以我们把这个
admin.conf
文件下载到本地,拷贝到
C:\Users\your user name\.kube\
目录下
3、验证
-
kubectl config get-contexts
image.png
-
kubectl get nodes
image.png
猜测是因为虚拟机的时间跟本地不同
image.png
- 修复
timedatectl set-local-rtc 1
timedatectl set-timezone Asia/Shanghai
yum -y install ntp
#通过阿里云时间服务器校准时间
ntpdate ntp1.aliyun.com
#时间信息写入硬件
hwclock -w
data:image/s3,"s3://crabby-images/4f8f4/4f8f4ae5722dc7360bc0e2b807c63179d932ea6f" alt=""
-
重试
image.png
二、安装Dashboard
0、参考文章
- kubernetes.io 网页界面 (Dashboard)
- https://github.com/kubernetes/dashboard
- Creating sample user
- Kubernetes Dashboard 安装与使用
- How To Install Kubernetes Dashboard with NodePort
- Kubernetes的三种外部访问方式:NodePort、LoadBalancer 和 Ingress
- 浅析从外部访问 Kubernetes 集群中应用的几种方式
1、安装
- 下载文件到本地
https://raw.githubusercontent.com/kubernetes/dashboard/v2.0.3/aio/deploy/recommended.yaml
- 安装
kubectl apply -f .\kubernetes-dashboard.yaml
data:image/s3,"s3://crabby-images/7d489/7d4896fe8b28e1e23b272d92b4aeb029fd5a6b65" alt=""
- 查看运行情况
kubectl get pods -n kubernetes-dashboard
data:image/s3,"s3://crabby-images/11cf6/11cf6a2bb917c4e5c1fbd42382422785ea804436" alt=""
- 启用代理
kubectl proxy
data:image/s3,"s3://crabby-images/9732b/9732bb40c1d80fb88accf115c7fa47a4866c2089" alt=""
- 本地主机访问
http://localhost:8001/api/v1/namespaces/kubernetes-dashboard/services/https:kubernetes-dashboard:/proxy/
可以看到登录界面
image.png
2、授权
- 新建文件
auth.yaml
apiVersion: v1
kind: ServiceAccount
metadata:
name: admin-user
namespace: kubernetes-dashboard
---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRoleBinding
metadata:
name: admin-user
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: cluster-admin
subjects:
- kind: ServiceAccount
name: admin-user
namespace: kubernetes-dashboard
- kubectl 应用文件
kubectl apply -f .\auth.yaml
data:image/s3,"s3://crabby-images/10e52/10e52793c573b0290511155ad6af50255091f147" alt=""
kubectl get deployment -n kubernetes-dashboard
data:image/s3,"s3://crabby-images/84758/84758795467a8a26188aef7627aab1c12b7b7de9" alt=""
- 获取token
kubectl -n kubernetes-dashboard describe secret $(kubectl -n kubernetes-dashboard get secret | sls admin-user | ForEach-Object { $_ -Split '\s+' } | Select -First 1)
data:image/s3,"s3://crabby-images/ee91f/ee91f9eca26e1a5fc3b97ae69a6139e3f5234dfb" alt=""
kubectl -n kubernetes-dashboard describe secret $(kubectl -n kubernetes-dashboard get secret | grep admin-user | awk '{print $1}')
- 复制
token
串,粘贴到登录界面即可
3.1、改为NodePort
data:image/s3,"s3://crabby-images/0697d/0697d3b23e1bd852559dbd5198f744bbe418b6a6" alt=""
kubectl edit service kubernetes-dashboard -n kubernetes-dashboard
将上图的值改为NodePort
,保存
data:image/s3,"s3://crabby-images/43ccd/43ccde0fba95459b77122485ff08e361bc955b4a" alt=""
kubectl get svc --all-namespaces
data:image/s3,"s3://crabby-images/29ab9/29ab9d8863ebcb3bb28e02f4693a75fe514e6b69" alt=""
3.2、改为NodePort
-- 另一种方式
- 回滚之前的操作
kubectl delete -f .\auth.yaml
kubectl delete -f .\kubernetes-dashboard.yaml
- 修改
kubernetes-dashboard.yaml
Service
下添加type: NodePort
image.png
- 部署
kubectl apply -f .\kubernetes-dashboard.yaml
kubectl get deployments -n kubernetes-dashboard
kubectl get pods -n kubernetes-dashboard
kubectl get service -n kubernetes-dashboard
data:image/s3,"s3://crabby-images/d4e07/d4e07198ee92e688190d3fa93031087e670da51e" alt=""
kubectl apply -f .\auth.yaml
data:image/s3,"s3://crabby-images/149de/149de37e79f7cb05038b951acee09aa5bb76c0c0" alt=""
- 访问
使用任意一个node节点【centos-master或centos-node】的ip+port即可访问
kubectl get svc -n kubernetes-dashboard
data:image/s3,"s3://crabby-images/fb9df/fb9df538fadf815eb24c6ecdabf93072ea287d3c" alt=""
https://192.168.32.129:30667
https://192.168.32.131:30667
经测试,谷歌浏览器无法访问,edge可以
复制token
,登录
kubectl -n kubernetes-dashboard describe secret $(kubectl -n kubernetes-dashboard get secret | sls admin-user | ForEach-Object { $_ -Split '\s+' } | Select -First 1)
data:image/s3,"s3://crabby-images/60d37/60d3710cc16a5ff7eaa24b1b9b17a9398d9b84cb" alt=""
网友评论