第八章 Helm 模板高效互用动态参数生成

简介: 第八章 Helm 模板高效互用动态参数生成

1.我们重新创建一个新的模板 helm create <应用名称>

[root@master01 hpro]# helm create mychart
Creating mychart

2.我们接着看文件

# 查看文件
[root@master01 mychart]# ls
charts  Chart.yaml  templates  values.yaml
 
# 我们进入 templates
[root@master01 templates]# ls
deployment.yaml  _helpers.tpl  hpa.yaml  ingress.yaml  NOTES.txt  serviceaccount.yaml  service.yaml  tests
 
# 我们随便查看一个yaml
[root@master01 templates]# vim service.yaml
# 这个是一个 helm创建的模板
apiVersion: v1
kind: Service
metadata:
  name: {{ include "mychart.fullname" . }}
  labels:
    {{- include "mychart.labels" . | nindent 4 }}
spec:
  type: {{ .Values.service.type }}
  ports:
    - port: {{ .Values.service.port }}
      targetPort: http
      protocol: TCP
      name: http
  selector:
    {{- include "mychart.selectorLabels" . | nindent 4 }}

3.模板取值格式

# 取参数的格式
# {{ .Values.变量名称 }}
# {{ .Release.Name }}

4.修改 values.yaml

[root@master01 mychart]# ls
charts  Chart.yaml  templates  values.yaml
 
# 把里面所有清空
[root@master01 mychart]# vim values.yaml
 
# 写入以下内容
 
# 定义副本数
replicas: 1
# 镜像
image: nginx
# 版本
tag: 1.16
# 标签
label: nginx
# 端口
port: 80

5. 修改 templates 文件夹中的deploy.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  creationTimestamp: null
  labels:
    app: {{.Values.label }}
  name: {{ .Release.Name}}-deploy
spec:
  replicas: 1
  selector:
    matchLabels:
      app: {{.Values.label }}
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: {{.Values.label }}
    spec:
      containers:
      - image: {{.Values.image }}
        name: {{.Values.image }}
        resources: {}
status: {}

6. 修改 templates 文件夹中的 service.yaml

apiVersion: v1
kind: Service
metadata:
  labels:
    app: web-test
  name: {{ .Release.Name}}-svc
spec:
  ports:
  - port: {{ .Values.port}}
    protocol: TCP
    targetPort: 80
  selector:
    app: {{ .Values.label}}
  type: NodePort

7.这是创建的模板文件

[root@master01 templates]# ls
deploy.yaml  service.yaml

8.测试模板文件  helm install --dry-run <应用名称> <模板文件夹>

命令的解释如下:

  • helm install: 这是 Helm 的安装命令,用于安装一个 chart。
  • --dry-run: 这个选项表示在执行安装命令时只进行模拟操作,不实际安装 chart。
  • web2: 这是要安装的 release 的名称。
  • mychart/: 这是要安装的 chart 的路径。

helm install --dry-run web2 mychart/ 这个命令将模拟安装位于 mychart/ 的 chart,不会实际执行任何操作。可以通过这个命令来检查安装过程中可能出现的问题或验证 chart 的配置是否正确。

 

1. # 正常打印表示文件没有问题
2. [root@master01 hpro]# helm install --dry-run web2 mychart/
3. NAME: web2
4. LAST DEPLOYED: Sun Jan 14 02:49:27 2024
5. NAMESPACE: default
6. STATUS: pending-install
7. REVISION: 1
8. TEST SUITE: None
9. HOOKS:
10. MANIFEST:
11. ---
12. .
13. .
14. .

9.我们看一下打印的内容,填充的内容都已经填充上了

1. # 取参数的格式
2. # {{ .Values.变量名称 }}
3. # {{ .Release.Name }}
4. 
5. # 这下明白怎么取值了吧
6. 
7. .Values 取得是 values.yaml 文件中的属性
8. 
9. .Release 取得是 install 中定义的名字
1. [root@master01 hpro]# helm install --dry-run web2 mychart/
2. NAME: web2
3. LAST DEPLOYED: Sun Jan 14 02:49:27 2024
4. NAMESPACE: default
5. STATUS: pending-install
6. REVISION: 1
7. TEST SUITE: None
8. HOOKS:
9. MANIFEST:
10. ---
11. # Source: mychart/templates/service.yaml
12. apiVersion: v1
13. kind: Service
14. metadata:
15.   labels:
16.     app: web-test
17.   name: web2-svc
18. spec:
19.   ports:
20.   - port: 80
21.     protocol: TCP
22.     targetPort: 80
23.   selector:
24.     app: nginx
25. type: NodePort
26. ---
27. # Source: mychart/templates/deploy.yaml
28. apiVersion: apps/v1
29. kind: Deployment
30. metadata:
31.   creationTimestamp: null
32.   labels:
33.     app: nginx
34.   name: web2-deploy
35. spec:
36.   replicas: 1
37.   selector:
38.     matchLabels:
39.       app: nginx
40.   strategy: {}
41.   template:
42.     metadata:
43.       creationTimestamp: null
44.       labels:
45.         app: nginx
46.     spec:
47.       containers:
48.       - image: nginx
49.         name: nginx
50.         resources: {}
51. status: {}

10.安装自定义应用

1. [root@master01 hpro]# helm install web2 mychart/
2. NAME: web2
3. LAST DEPLOYED: Sun Jan 14 02:58:44 2024
4. NAMESPACE: default
5. STATUS: deployed
6. REVISION: 1
7. TEST SUITE: None
8. [root@master01 hpro]# helm list
9. NAME    NAMESPACE       REVISION        UPDATED                                 STATUS          CHART           APP VERSION
10. web2    default         1               2024-01-14 02:58:44.222147967 -0800 PST deployed        mychart-0.1.0   1.16.0
11. [root@master01 hpro]# kubectl get pod
12. NAME                          READY   STATUS    RESTARTS   AGE
13. web2-deploy-f89759699-rqc6m   1/1     Running   0          21s
14. [root@master01 hpro]# kubectl get svc
15. NAME         TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE
16. kubernetes   ClusterIP   10.96.0.1        <none>        443/TCP        28d
17. web2-svc     NodePort    10.108.230.159   <none>        80:31223/TCP   25s


总结:本章学习怎么定义模板,怎么取值运行。

相关文章
|
8月前
|
设计模式 程序员 C++
【C++ 泛型编程 高级篇】C++模板元编程:使用模板特化 灵活提取嵌套类型与多容器兼容性
【C++ 泛型编程 高级篇】C++模板元编程:使用模板特化 灵活提取嵌套类型与多容器兼容性
947 2
|
3月前
|
开发框架 供应链 监控
并行开发模型详解:类型、步骤及其应用解析
在现代研发环境中,企业需要在有限时间内推出高质量的产品,以满足客户不断变化的需求。传统的线性开发模式往往拖慢进度,导致资源浪费和延迟交付。并行开发模型通过允许多个开发阶段同时进行,极大提高了产品开发的效率和响应能力。本文将深入解析并行开发模型,涵盖其类型、步骤及如何通过辅助工具优化团队协作和管理工作流。
97 3
|
5月前
|
XML JSON 计算机视觉
LangChain 构建问题之智能代理类型中的“预期模型类型”的定义如何解决
LangChain 构建问题之智能代理类型中的“预期模型类型”的定义如何解决
38 0
|
8月前
|
Java Linux Go
流水线 YAML 高级用法来了,大幅降低重复代码、灵活编排多任务
云效 Flow 流水线 YAML 引入了 template 语法,支持使用模板语言来动态渲染流水线 YAML,满足多个相同或类似逻辑的 Job 批量配置场景,满足多 Job 按需动态生成场景,帮助降低流水线 YAML 重复代码,灵活编排多任务。
70742 10
|
8月前
|
存储 Kubernetes 应用服务中间件
第七章 自定义Chart并部署一个应用
第七章 自定义Chart并部署一个应用
100 1
|
8月前
|
编译器 定位技术 C++
【CMake高级技巧】如何创建一个通用的库查找模板?
【CMake高级技巧】如何创建一个通用的库查找模板?
101 0
|
存储 数据可视化 Ubuntu
bcftools学习笔记丨软件简介、安装方式、使用方法、核心功能、参数解释等一文速览
bcftools学习笔记丨软件简介、安装方式、使用方法、核心功能、参数解释等一文速览
|
机器人 API 区块链
Pionex派网量化网格交易机器人开发策略部署[源码执行规则示例]
Pionex派网量化网格交易机器人开发策略部署[源码执行规则示例]
|
XML 存储 JSON
【工作中问题解决实践 四】动态解析Json结构最佳实践(下)
【工作中问题解决实践 四】动态解析Json结构最佳实践(下)
282 0
|
XML 存储 JSON
【工作中问题解决实践 四】动态解析Json结构最佳实践(上)
【工作中问题解决实践 四】动态解析Json结构最佳实践(上)
448 0