k8s-helm yaml文件高效复用---参数方式

简介: k8s-helm yaml文件高效复用---参数方式

(1)创建完一个chart:mychart

[root@k8s-master helm]# helm create mychart
Creating mychart
[root@k8s-master mychart]# ls
charts  Chart.yaml  templates  values.yaml
mychart                                   - chart 包目录名
├── charts                              - 依赖的子包目录,里面可以包含多个依赖的chart包
├── Chart.yaml                          - chart定义,可以定义chart的名字,版本号信息。
├── templates                           - k8s配置模版目录, 我们编写的k8s配置都在这个目录, 除了NOTES.txt和下划线开头命名的文件,其他文件可以随意命名。
│   ├── deployment.yaml
│   ├── _helpers.tpl                    - 下划线开头的文件,helm视为公共库定义文件,主要用于定义通用的子模版、函数等,helm不会将这些公共库文件的渲染结果提交给k8s处理。
│   ├── ingress.yaml
│   ├── NOTES.txt                       - chart包的帮助信息文件,执行helm install命令安装成功后会输出这个文件的内容。
│   └── service.yaml
└── values.yaml                         - chart包的参数配置文件,模版可以引用这里参数。

(2)新增变量,修改变量文件values.yaml

[root@k8s-master mychart]# vim values.yaml 
在对底部添加
#自定义变量
replicas: 2
image: nginx
tag: 1.16
label: nginx
port: 80


(3)修改pod的yaml文件,在template目录下


指定参数格式: {{  }}

{{ .Release.Name }}  pod应用名
{{ .Values.变量名称 }}   变量名称是根据mychart/values.yaml文件新增的参数
[root@k8s-master templates]# cat deployment.yaml 
apiVersion: apps/v1
kind: Deployment
metadata:
  creationTimestamp: null
  labels:
    app: web
  name: {{ .Release.Name }}-nginx       #pod的名字
spec:
  replicas: {{ .Values.replicas }}      #pod的副本数
  selector:
    matchLabels:
      app: {{ .Values.label }}          #pod标签选择器
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: {{ .Values.label }}       #设置此模板的标签
    spec:
      containers:
      - image: {{ .Values.image }}
        name: nginx
        resources: {}
status: {}
[root@k8s-master templates]# cat service.yaml 
apiVersion: v1
kind: Service
metadata:
  creationTimestamp: null
  labels:
    app: {{ .Release.Name }}-svc
  name: {{ .Release.Name }}-svc
spec:
  ports:
  - port: {{ .Values.port }}
    protocol: TCP
    targetPort: 80
  selector:
    app: {{ .Values.label }}
  type: NodePort
status:
  loadBalancer: {}


(4)创建自定义参数pod

[root@k8s-master helm]# helm install web7 mychart
NAME: web7
LAST DEPLOYED: Fri Nov 13 20:09:20 2020
NAMESPACE: default
STATUS: deployed
REVISION: 1
TEST SUITE: None

(5)验证

[root@k8s-master helm]# kubectl get svc
NAME             TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
kubernetes       ClusterIP   10.96.0.1       <none>        443/TCP        51d
ui-weave-scope   NodePort    10.102.105.28   <none>        80:32448/TCP   16d
web              NodePort    10.98.105.180   <none>        80:31375/TCP   25h
web7-svc         NodePort    10.111.115.9    <none>        80:31687/TCP   103m               与预期一致,端口号80
[root@k8s-master helm]# kubectl get pod
NAME                                            READY   STATUS        RESTARTS   AGE
weave-scope-agent-ui-655pp                      1/1     Running       3          16d
weave-scope-agent-ui-bzttt                      1/1     Running       2          16d
weave-scope-agent-ui-hkxfz                      1/1     Running       1          16d
weave-scope-cluster-agent-ui-5d4d6c97bf-5xpqf   1/1     Terminating   0          9d
weave-scope-cluster-agent-ui-5d4d6c97bf-f528k   1/1     Running       1          8d
weave-scope-frontend-ui-757c6668c5-vqpdj        1/1     Running       1          8d
weave-scope-frontend-ui-757c6668c5-zhlzp        1/1     Terminating   0          9d
web-d86c95cc9-vzmnd                             1/1     Running       0          25h
web7-nginx-86c57db685-f86b8                     1/1     Running       0          105m
web7-nginx-86c57db685-hd2b7                     1/1     Running       0          105m          #与预期一致,副本数2


浏览器访问http://ip:31687

1675173358799.jpg

完成

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
6月前
|
Java 测试技术 数据安全/隐私保护
通过yaml文件配置自动化测试程序
通过yaml文件可以将自动化测试环境,测试数据和测试行为分开,请看一下案例
208 4
|
12月前
|
Kubernetes Docker 容器
Kubernetes与Docker参数对照:理解Pod中的command、args与Dockerfile中的CMD、ENTRYPOINT。
需要明确的是,理解这些都需要对Docker和Kubernetes有一定深度的理解,才能把握二者的区别和联系。虽然它们都是容器技术的二个重要组成部分,但各有其特性和适用场景,理解它们的本质和工作方式,才能更好的使用这些工具,将各自的优点整合到生产环境中,实现软件的快速开发和部署。
464 25
|
Kubernetes 应用服务中间件 nginx
k8s学习--YAML资源清单文件托管服务nginx
k8s学习--YAML资源清单文件托管服务nginx
378 2
k8s学习--YAML资源清单文件托管服务nginx
|
Kubernetes Cloud Native 流计算
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
433 3
ingress相关yaml文件报错且相关资源一切正常解决方法
ingress相关yaml文件报错且相关资源一切正常解决方法
176 0
ingress相关yaml文件报错且相关资源一切正常解决方法
|
JSON Kubernetes API
深入理解Kubernetes配置:编写高效的YAML文件
深入理解Kubernetes配置:编写高效的YAML文件
|
存储 运维 Serverless
函数计算产品使用问题之在YAML文件中配置了环境变量,但在PHP代码中无法读取到这些环境变量,是什么原因
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
325 1
|
Kubernetes Docker Perl
k8s常见故障--yaml文件检查没有问题 pod起不来(一直处于创建中)
k8s常见故障--yaml文件检查没有问题 pod起不来(一直处于创建中)
592 1
|
运维 Kubernetes Serverless
Serverless 应用引擎使用问题之s.yaml文件中如何使用外部环境变量
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。

热门文章

最新文章

推荐镜像

更多