当前位置:首页 > 文章列表 > Golang > Go问答 > 如何将变量值传递给 Helm 图表中的 .Files.Glob?

如何将变量值传递给 Helm 图表中的 .Files.Glob?

来源:stackoverflow 2024-03-31 15:45:33 0浏览 收藏

在Golang实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《如何将变量值传递给 Helm 图表中的 .Files.Glob?》,聊聊,希望可以帮助到正在努力赚钱的你。

问题内容

下面对 .files.glob 的调用需要来自作为 .values.initdbfilesglob 的值提供的变量。该值已正确设置,但 if 条件未计算为真,即使 .values.initdbconfigmap 为空。

如何将变量参数传递给 .files.glob

有问题的模板(来自我的 wip 图表的 templates/initdb-configmap.yaml https://github.com/northscaler/charts/tree/support-env-specific-init/bitnami/cassandra,我将提交到 https修复此问题后,将://github.com/bitnami/charts/tree/master/bitnami/cassandra 作为 pr):

{{- $initdbfilesglob := .values.initdbfilesglob -}}
# "{{ $initdbfilesglob }}" "{{ .values.initdbconfigmap }}"
# there should be content below this
{{- if and (.files.glob $initdbfilesglob) (not .values.initdbconfigmap) }}
apiversion: v1
kind: configmap
metadata:
  name: {{ include "cassandra.fullname" . }}-init-scripts
  labels: {{- include "cassandra.labels" . | nindent 4 }}
data:
{{ (.files.glob $initdbfilesglob).asconfig | indent 2 }}
{{- end }}

文件 values.yaml

dbuser:
  forcepassword: true
  password: cassandra
initdbfilesglob: 'files/devops/docker-entrypoint-initdb.d/*'

命令:helm template -f value.yaml foobar /users/matthewadams/dev/bitnami/charts/bitnami/cassandra

相对于我调用命令的目录,files/devops/docker-entrypoint-initdb.d 中有 个文件。

输出:

---
# source: cassandra/templates/pdb.yaml
apiversion: policy/v1beta1
kind: poddisruptionbudget
metadata:
  name: foobar-cassandra-headless
  labels:
    app: cassandra
    chart: cassandra-5.1.2
    release: foobar
    heritage: helm
spec:
  selector:
    matchlabels:
      app: cassandra
      release: foobar
  maxunavailable: 1
---
# source: cassandra/templates/cassandra-secret.yaml
apiversion: v1
kind: secret
metadata:
  name: foobar-cassandra
  labels:
    app: cassandra
    chart: cassandra-5.1.2
    release: foobar
    heritage: helm
type: opaque
data:
  cassandra-password: "y2fzc2fuzhjh"
---
# source: cassandra/templates/configuration-cm.yaml
# files/conf/*

apiversion: v1
kind: configmap
# files/conf/*
metadata:
  name: foobar-cassandra-configuration
  labels:
    app: cassandra
    chart: cassandra-5.1.2
    release: foobar
    heritage: helm
data:
  readme.md: |
    place your cassandra configuration files here. this will override the values set in any configuration environment variable. this will not be used in case the value *existingconfiguration* is used.

    more information [here](https://github.com/bitnami/bitnami-docker-cassandra#configuration)
---
# source: cassandra/templates/headless-svc.yaml
apiversion: v1
kind: service
metadata:
  name: foobar-cassandra-headless
  labels:
    app: cassandra
    chart: cassandra-5.1.2
    release: foobar
    heritage: helm
spec:
  clusterip: none
  publishnotreadyaddresses: true
  ports:
    - name: intra
      port: 7000
      targetport: intra
    - name: tls
      port: 7001
      targetport: tls
    - name: jmx
      port: 7199
      targetport: jmx
    - name: cql
      port: 9042
      targetport: cql
    - name: thrift
      port: 9160
      targetport: thrift
  selector:
    app: cassandra
    release: foobar
---
# source: cassandra/templates/service.yaml
apiversion: v1
kind: service
metadata:
  name: foobar-cassandra
  labels:
    app: cassandra
    chart: cassandra-5.1.2
    release: foobar
    heritage: helm
  annotations: 
    {}
spec:
  type: clusterip
  ports:
    - name: cql
      port: 9042
      targetport: cql
      nodeport: null
    - name: thrift
      port: 9160
      targetport: thrift
      nodeport: null
  selector:
    app: cassandra
    release: foobar
---
# source: cassandra/templates/statefulset.yaml
apiversion: apps/v1
kind: statefulset
metadata:
  name: foobar-cassandra
  labels:
    app: cassandra
    chart: cassandra-5.1.2
    release: foobar
    heritage: helm
spec:
  selector:
    matchlabels:
      app: cassandra
      release: foobar
  servicename: foobar-cassandra-headless
  replicas: 1
  updatestrategy:
    type: ondelete
  template:
    metadata:
      labels:
        app: cassandra
        chart: cassandra-5.1.2
        release: foobar
        heritage: helm
    spec:

      securitycontext:
        fsgroup: 1001
        runasuser: 1001
      containers:
        - name: cassandra
          command:
            - bash
            - -ec
            # node 0 is the password seeder
            - |
              if [[ $hostname =~ (.*)-0$ ]]; then
                echo "setting node as password seeder"
                export cassandra_password_seeder=yes
              else
                # only node 0 will execute the startup initdb scripts
                export cassandra_ignore_initdb_scripts=1
              fi
              /entrypoint.sh /run.sh
          image: docker.io/bitnami/cassandra:3.11.6-debian-10-r26
          imagepullpolicy: "ifnotpresent"
          env:
            - name: bitnami_debug
              value: "false"
            - name: cassandra_cluster_name
              value: cassandra
            - name: cassandra_seeds
              value: "foobar-cassandra-0.foobar-cassandra-headless.default.svc.cluster.local"
            - name: cassandra_password
              valuefrom:
                secretkeyref:
                  name: foobar-cassandra
                  key: cassandra-password
            - name: pod_ip
              valuefrom:
                fieldref:
                  fieldpath: status.podip
            - name: cassandra_user
              value: "cassandra"
            - name: cassandra_num_tokens
              value: "256"
            - name: cassandra_datacenter
              value: dc1
            - name: cassandra_endpoint_snitch
              value: simplesnitch
            - name: cassandra_endpoint_snitch
              value: simplesnitch
            - name: cassandra_rack
              value: rack1
            - name: cassandra_enable_rpc
              value: "true"
          livenessprobe:
            exec:
              command: ["/bin/sh", "-c", "nodetool status"]
            initialdelayseconds: 60
            periodseconds: 30
            timeoutseconds: 5
            successthreshold: 1
            failurethreshold: 5
          readinessprobe:
            exec:
              command: ["/bin/sh", "-c", "nodetool status | grep -e \"^un\\s+${pod_ip}\""]
            initialdelayseconds: 60
            periodseconds: 10
            timeoutseconds: 5
            successthreshold: 1
            failurethreshold: 5
          ports:
            - name: intra
              containerport: 7000
            - name: tls
              containerport: 7001
            - name: jmx
              containerport: 7199
            - name: cql
              containerport: 9042
            - name: thrift
              containerport: 9160
          resources: 
            limits: {}
            requests: {}
          volumemounts:
            - name: data
              mountpath: /bitnami/cassandra
            - name: init-db
              mountpath: /docker-entrypoint-initdb.d

            - name: configurations
              mountpath: /bitnami/cassandra/conf
      volumes:
        - name: configurations
          configmap:
            name: foobar-cassandra-configuration
        - name: init-db
          configmap:
            name: foobar-cassandra-init-scripts
  volumeclaimtemplates:
    - metadata:
        name: data
        labels:
          app: cassandra
          release: foobar
      spec:
        accessmodes:
          - "readwriteonce"
        resources:
          requests:
            storage: "8gi"
---
# source: cassandra/templates/initdb-configmap.yaml
# "files/devops/docker-entrypoint-initdb.d/*" ""
# there should be content below this

如果我注释掉 values.yaml 中设置 initdbfilesglob 的行,模板将正确呈现:

...
---
# Source: cassandra/templates/initdb-configmap.yaml
# "files/docker-entrypoint-initdb.d/*" ""
# There should be content below this
apiVersion: v1
kind: ConfigMap
metadata:
  name: foobar-cassandra-init-scripts
  labels:
    app: cassandra
    chart: cassandra-5.1.2
    release: foobar
    heritage: Helm
data:
  README.md: |
    You can copy here your custom `.sh` or `.cql` file so they are executed during the first boot of the image.

    More info in the [bitnami-docker-cassandra](https://github.com/bitnami/bitnami-docker-cassandra#initializing-a-new-instance) repository.

解决方案


我可以通过使用 printf 函数初始化变量来完成此操作,如下所示:

{{- $initDBFilesGlob := printf "%s" .Values.initDBFilesGlob -}}

以上就是《如何将变量值传递给 Helm 图表中的 .Files.Glob?》的详细内容,更多关于的资料请关注golang学习网公众号!

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
Istio 多集群之间的流量管理Istio 多集群之间的流量管理
上一篇
Istio 多集群之间的流量管理
golang运行时包设置构建它的系统的文件路径
下一篇
golang运行时包设置构建它的系统的文件路径
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    511次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    498次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 千音漫语:智能声音创作助手,AI配音、音视频翻译一站搞定!
    千音漫语
    千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
    206次使用
  • MiniWork:智能高效AI工具平台,一站式工作学习效率解决方案
    MiniWork
    MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
    209次使用
  • NoCode (nocode.cn):零代码构建应用、网站、管理系统,降低开发门槛
    NoCode
    NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
    205次使用
  • 达医智影:阿里巴巴达摩院医疗AI影像早筛平台,CT一扫多筛癌症急慢病
    达医智影
    达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
    212次使用
  • 智慧芽Eureka:更懂技术创新的AI Agent平台,助力研发效率飞跃
    智慧芽Eureka
    智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
    230次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码