目录
[2.K8S master节点部署HELM3](#2.K8S master节点部署HELM3)
[3.K8S master节点安装git](#3.K8S master节点安装git)
[4. Harbor镜像确认](#4. Harbor镜像确认)
[5. HELM 手动完成前端项目应用发布与回滚](#5. HELM 手动完成前端项目应用发布与回滚)
[1.Ingress中 path 的类型有何区别](#1.Ingress中 path 的类型有何区别)
[2. HELM创建项目报错](#2. HELM创建项目报错)
一、实验
1.环境
(1)主机
表1 主机
|---------|--------------|----------|---------------------|---------------------|
| 主机 | 架构 | 版本 | IP | 备注 |
| master1 | K8S master节点 | 1.20.6 | 192.168.204.180 | jenkins slave (从节点) |
| | helm | 3.6.0 | | |
| | git | 1.8.3.1 | | |
| node1 | K8S node节点 | 1.20.6 | 192.168.204.181 | |
| node2 | K8S node节点 | 1.20.6 | 192.168.204.182 | |
| jenkins | jenkins主节点 | 2.414.2 | 192.168.204.15:8080 | gitlab runner (从节点) |
| | harbor私有仓库 | 1.2.2 | 192.168.204.15 | |
| gitlab | gitlab 主节点 | 12.10.14 | 192.168.204.8:82 | jenkins slave (从节点) |
| | sonarqube | 9.6 | 192.168.204.8:9000 | |
2.K8S master节点部署HELM3
(1)Helm版本与K8S集群兼容
data:image/s3,"s3://crabby-images/b0037/b0037c54f0a7d091693e327f7dd02bdd8ba61cc5" alt=""
(2)查看K8S集群状态
bash
# kubectl get node
data:image/s3,"s3://crabby-images/ac8bb/ac8bbc7a8e014a7462e4260f8df8207b9537fde9" alt=""
(3)策略
当前K8S 集群为1.20.6版本,HELM 3.6.x 版本可以兼容。
所以选择3.6.0版本。
(4)部署
bash
1)安装 helm
//下载二进制 Helm client 安装包
helm-v3.6.0-linux-amd64.tar.gz
tar -zxvf helm-v3.6.0-linux-amd64.tar.gz
mv linux-amd64/helm /usr/local/bin/helm
helm version
//命令补全
source <(helm completion bash)
2)使用 helm 安装 Chart
//添加常用的 chart 仓库,
helm repo add bitnami https://charts.bitnami.com/bitnami
helm repo add aliyun https://kubernetes.oss-cn-hangzhou.aliyuncs.com/charts
helm repo add incubator https://charts.helm.sh/incubator
3) 更新 charts 列表
helm repo update
helm repo list
安装
data:image/s3,"s3://crabby-images/8788d/8788d77bb9e60cae6d8c877cede185f3ff01515b" alt=""
使用 helm 安装 Chart
3.K8S master节点安装git
(1) 安装
bash
1)安装
# yum install -y git
2)查看版本
# git --version
3)全局设置(初始邮箱为admin@example.com)
# git config --global user.name "root"
# git config --global user.email "594372682@qq.com"
安装
查看版本
data:image/s3,"s3://crabby-images/c301a/c301aaecde4f81d7339f8bb3379ab479118c60e0" alt=""
全局设置
4. Harbor镜像确认
(1)查看前端项目镜像
data:image/s3,"s3://crabby-images/51e73/51e73dc25f87bc60060c518f4a225f2218ea212b" alt=""
(2)确认如下镜像作为helm项目使用的镜像
bash
192.168.204.15/devops03/devops03-devops-ui:RELEASE-1.1.6
5. HELM 手动完成前端项目应用发布与回滚
(1)构建项目
bash
# helm create devops03-devops-ui
data:image/s3,"s3://crabby-images/5befd/5befdb0718c48b255daf1bb1c759181a1733f3b4" alt=""
(2)安装tree
bash
# yum install -y tree
(3) 查看目录
bash
# tree
data:image/s3,"s3://crabby-images/442bd/442bde695c517f7a875ae352f60c4998e642be11" alt=""
(4)修改values.yaml
bash
# vim values.yaml
指定镜像仓库、镜像版本为RELEASE-1.1.6、开启ingress
bash
1 # Default values for devops03-devops-ui.
2 # This is a YAML-formatted file.
3 # Declare variables to be passed into your templates.
4
5 replicaCount: 2
6
7 image:
8 repository: 192.168.204.15/devops03/devops03-devops-ui
9 pullPolicy: IfNotPresent
10 # Overrides the image tag whose default is the chart appVersion.
11 tag: "RELEASE-1.1.6"
12
13 imagePullSecrets: []
14 nameOverride: ""
15 fullnameOverride: ""
16
17 serviceAccount:
18 # Specifies whether a service account should be created
19 create: true
20 # Annotations to add to the service account
21 annotations: {}
22 # The name of the service account to use.
23 # If not set and create is true, a name is generated using the fullname template
24 name: ""
25
26 podAnnotations: {}
27
28 podSecurityContext: {}
29 # fsGroup: 2000
30
31 securityContext: {}
32 # capabilities:
33 # drop:
34 # - ALL
35 # readOnlyRootFilesystem: true
36 # runAsNonRoot: true
37 # runAsUser: 1000
38
39 service:
40 type: ClusterIP
41 port: 80
42
43 ingress:
44 enabled: true
45 className: ""
46 annotations:
47 kubernetes.io/ingress.class: nginx
48 # kubernetes.io/tls-acme: "true"
49 hosts:
50 - host: devops03-devops-ui.devops.com
51 paths:
52 - path: /
53 pathType: ImplementationSpecific
54 tls: []
55 # - secretName: chart-example-tls
56 # hosts:
57 # - chart-example.local
58
59 resources: {}
60 # We usually recommend not to specify default resources and to leave this as a conscious
61 # choice for the user. This also increases chances charts run on environments with little
62 # resources, such as Minikube. If you do want to specify resources, uncomment the following
63 # lines, adjust them as necessary, and remove the curly braces after 'resources:'.
64 # limits:
65 # cpu: 100m
66 # memory: 128Mi
67 # requests:
68 # cpu: 100m
69 # memory: 128Mi
70
71 autoscaling:
72 enabled: false
73 minReplicas: 1
74 maxReplicas: 100
75 targetCPUUtilizationPercentage: 80
76 # targetMemoryUtilizationPercentage: 80
77
78 nodeSelector: {}
79
80 tolerations: []
81
82 affinity: {}
(5) 另开一个终端用watch命令观察pod变化
# watch -n 1 "kubectl get pod -n devops03"
data:image/s3,"s3://crabby-images/42027/42027d0960d381d23cf60d3fb4035ad75c389f1c" alt=""
data:image/s3,"s3://crabby-images/37a51/37a51f0a736d5276e93272482acdb6c6175bd323" alt=""
(6)外部测试访问(当前版本为1.1.6)
# curl http://devops03-devops-ui.devops.com:31291
data:image/s3,"s3://crabby-images/69f33/69f335e3aa813e3499af00b33dda85a29066b87c" alt=""
(7)删除已有命名空间
bash
# kubectl delete ns devops03
data:image/s3,"s3://crabby-images/356ae/356ae2ac464703e04662f601807fb5bf70a5362e" alt=""
(8)观察pod变化
data:image/s3,"s3://crabby-images/d6699/d66991bf5d1fcb47267203130c40368319e722d6" alt=""
(9)重新创建命名空间并查看资源
bash
# kubectl create ns devops03
# kubectl get all -n devops03
data:image/s3,"s3://crabby-images/85a4b/85a4ba7a3361cbf413b98545cc9b0aa140989932" alt=""
data:image/s3,"s3://crabby-images/56c84/56c84da88d2a07f289a996b293c3619b0c201365" alt=""
(7)运行项目
bash
# helm install devops03-devops-ui -n devops03 devops03-devops-ui/
data:image/s3,"s3://crabby-images/4e9a5/4e9a5a236dd791cd046c12e7404e3cbb9c0622a4" alt=""
(8)观察pod变化
data:image/s3,"s3://crabby-images/df64b/df64b4d6a8ce0c7d7adacd2d80ca252c546335e5" alt=""
data:image/s3,"s3://crabby-images/98e6f/98e6fd61c505661ba92bab671818d4955b2894cb" alt=""
data:image/s3,"s3://crabby-images/6c628/6c628ae03afd377e221978ec76f8d48f1fd4a78a" alt=""
(9)外部测试访问(当前版本为1.1.6)
# curl http://devops03-devops-ui.devops.com:31291
data:image/s3,"s3://crabby-images/88cc5/88cc5ad8a6d5f9a13699202223b889337f54d286" alt=""
(10)修改values.yaml
bash
# vim values.yaml
指定镜像仓库、镜像版本为RELEASE-1.1.5、开启ingress
bash
1 # Default values for devops03-devops-ui.
2 # This is a YAML-formatted file.
3 # Declare variables to be passed into your templates.
4
5 replicaCount: 2
6
7 image:
8 repository: 192.168.204.15/devops03/devops03-devops-ui
9 pullPolicy: IfNotPresent
10 # Overrides the image tag whose default is the chart appVersion.
11 tag: "RELEASE-1.1.6"
12
13 imagePullSecrets: []
14 nameOverride: ""
15 fullnameOverride: ""
16
17 serviceAccount:
18 # Specifies whether a service account should be created
19 create: true
20 # Annotations to add to the service account
21 annotations: {}
22 # The name of the service account to use.
23 # If not set and create is true, a name is generated using the fullname template
24 name: ""
25
26 podAnnotations: {}
27
28 podSecurityContext: {}
29 # fsGroup: 2000
30
31 securityContext: {}
32 # capabilities:
33 # drop:
34 # - ALL
35 # readOnlyRootFilesystem: true
36 # runAsNonRoot: true
37 # runAsUser: 1000
38
39 service:
40 type: ClusterIP
41 port: 80
42
43 ingress:
44 enabled: true
45 className: ""
46 annotations:
47 kubernetes.io/ingress.class: nginx
48 # kubernetes.io/tls-acme: "true"
49 hosts:
50 - host: devops03-devops-ui.devops.com
51 paths:
52 - path: /
53 pathType: ImplementationSpecific
54 tls: []
55 # - secretName: chart-example-tls
56 # hosts:
57 # - chart-example.local
58
59 resources: {}
60 # We usually recommend not to specify default resources and to leave this as a conscious
61 # choice for the user. This also increases chances charts run on environments with little
62 # resources, such as Minikube. If you do want to specify resources, uncomment the following
63 # lines, adjust them as necessary, and remove the curly braces after 'resources:'.
64 # limits:
65 # cpu: 100m
66 # memory: 128Mi
67 # requests:
68 # cpu: 100m
69 # memory: 128Mi
70
71 autoscaling:
72 enabled: false
73 minReplicas: 1
74 maxReplicas: 100
75 targetCPUUtilizationPercentage: 80
76 # targetMemoryUtilizationPercentage: 80
77
78 nodeSelector: {}
79
80 tolerations: []
81
82 affinity: {}
修改前:
data:image/s3,"s3://crabby-images/ef7f7/ef7f7cc50c8d4364bc2799d6155ae2a868cfbcd7" alt=""
修改后:
data:image/s3,"s3://crabby-images/82af6/82af68db7edb4d29c6e4caaaec7691ef1b65c3e7" alt=""
(11)更新项目
bash
# helm upgrade devops03-devops-ui -n devops03 devops03-devops-ui/
data:image/s3,"s3://crabby-images/3566f/3566ff7ccc53d38f2f6bd88525ab62e5199f9df5" alt=""
(12)观察pod变化
data:image/s3,"s3://crabby-images/233eb/233eb080084603ed8b61e124344deefed96ed0c7" alt=""
data:image/s3,"s3://crabby-images/caae0/caae0e33c1668bc66e61b534296add910b66ec1d" alt=""
data:image/s3,"s3://crabby-images/3416b/3416ba422b49bfefb488f454b6f97fe368cb5dfc" alt=""
data:image/s3,"s3://crabby-images/17d0d/17d0dc8313bcba1cce17885914acc841698d32c6" alt=""
data:image/s3,"s3://crabby-images/05180/05180204d242ae0340346c05bb28fb816ff5d4d4" alt=""
(13)外部测试访问(当前版本为1.1.5)
# curl http://devops03-devops-ui.devops.com:31291
data:image/s3,"s3://crabby-images/888cd/888cda92fd4b994bff88078cb024239c0636ce49" alt=""
(14)查看历史版本
bash
# helm history devops03-devops-ui -n devops03
data:image/s3,"s3://crabby-images/ea8c8/ea8c8fe53eb6ba7a5f7724f45610231c4093e9ab" alt=""
(15)回滚指定版本
bash
# helm rollback devops03-devops-ui 1 -n devops03
data:image/s3,"s3://crabby-images/c1ff9/c1ff9d64eb0f93c2d1f9a3677906b559a754fc9c" alt=""
(16)观察pod变化
data:image/s3,"s3://crabby-images/e495e/e495ef5e281544aaa42c5de618f6b19c39144831" alt=""
data:image/s3,"s3://crabby-images/cf4c4/cf4c4365e36c9b752b4ac283c05708d254fb1e32" alt=""
data:image/s3,"s3://crabby-images/f505f/f505f1b0b8a0d9e2ed2fbf4bed59182e5b0cc28d" alt=""
data:image/s3,"s3://crabby-images/1ba7a/1ba7a429cab72ee161c2688fdf9e47a1f3ccde69" alt=""
data:image/s3,"s3://crabby-images/3741e/3741e4cf921fee8ebf220c4973463d19ce0c8511" alt=""
(17)外部测试访问(当前版本为1.1.6)
# curl http://devops03-devops-ui.devops.com:31291
data:image/s3,"s3://crabby-images/579ee/579eeb7ee633fedd913888f2f83b9240906e3dab" alt=""
6.代码上传到GitLab
(1) 将项目克隆到服务器
bash
# git clone http://192.168.204.8:82/devops03/devops03-helm-service.git
data:image/s3,"s3://crabby-images/8e11f/8e11f7306c507de714e917f57b2cc35d636cc33d" alt=""
(2)切换目录,移动HELM项目
bash
# mv devops03-devops-ui/ devops03-helm-service/
data:image/s3,"s3://crabby-images/8339a/8339ab0987ac07ee9c25a147c6b557227ab5e9ed" alt=""
(3)将代码上传到工作区
bash
# git add devops03-devops-ui/
data:image/s3,"s3://crabby-images/74410/74410e4910ff4becd53a1eda9123e8e547b1ef3d" alt=""
(4)提交代码申明
bash
# git commit -m "devops03 app"
data:image/s3,"s3://crabby-images/72c78/72c7881dfc120f1b6e9152826b2f737ae11b08c7" alt=""
(5) 将代码推送到GitLab
bash
# git push origin master
data:image/s3,"s3://crabby-images/e2c53/e2c5309b60aee5c2432750682fadef9b06c131a4" alt=""
(6)GitLab查看项目
data:image/s3,"s3://crabby-images/e1b47/e1b4702ec9305ff9ac7655c7f2b45e3004944c94" alt=""
(7)目录结构
data:image/s3,"s3://crabby-images/c267d/c267d11e1b504ba8bd95ab34de0737128a6b51d9" alt=""
二、问题
1.Ingress中 path 的类型有何区别
(1)区别
bash
exact: 精确匹配路径。如 path: /foo,只匹配请求路径与之完全相同的 /foo。
prefix: 前缀匹配路径。如 path: /foo,匹配请求路径以 /foo 开始的所有路径,如 /foo、/foo/bar 等。
ImplementationSpecific: 特定 Ingress controller 的匹配方式。如 Nginx Ingress controller 忽略路径类型,作为前缀匹配路径处理。
2. HELM创建项目报错
(1)报错
data:image/s3,"s3://crabby-images/e3ae9/e3ae9cc32a32b380ac1d8b60c34eda185906983b" alt=""
(2)原因分析
格式转换错误。
(3)解决方法
修改配置文件。
修改前:
data:image/s3,"s3://crabby-images/70fb5/70fb5c74e239bde3b561bfddcbb078b72a2de983" alt=""
修改后:
data:image/s3,"s3://crabby-images/c1e46/c1e46ff5e2a9d5a57d70f0618a3692b0d9c06d44" alt=""
成功:
data:image/s3,"s3://crabby-images/b221b/b221b9c0883f9a82d6b50228cc22c6aa057bbd2f" alt=""