k8s的包管理工具(5)--读取文件内容

文章目录

一、概述

helm3中可通过.Files对象并结合方法获取文件内容,包含文件名称和文件具体内容。

通过这样的方式获取的文件内容不能是chart包创建后默认生成的文件内容,以下文件中的内容都无法获取到

复制代码
mychart/
├── charts/
├── templates/
├── Chart.yaml
└── values.yaml

在chart包内手动创建的文件夹,里面的文件内容可被获取

复制代码
mychart/
├── charts/
├── templates/
├── files/           # 只有这里的文件可以被 .Files.Get 访问
│   ├── config.json
│   └── data.txt
├── Chart.yaml
└── values.yaml

引用文件时,文件目录是相当路径,相当chart/

二、获取文件内容

1. 使用方法

获取文件内容的方法

yaml 复制代码
data: {{ .Files.Get "文件目录" }}   注意为相对目录

按找行获取文件内容

yaml 复制代码
data: {{ .Files.Lines "文件目录" }} 

获取文件路径和内容

yaml 复制代码
# 获取目录下所有文件路径
{{ .Files.Glob "目录/*" }}

## 递归匹配
{{ .Files.Glob "目录/**" }}

2. 示例

.Files.Get获取文件内容

创建chart包

bash 复制代码
[root@k8s-master m1]# helm create chart

[root@k8s-master m1]# cd chart/
[root@k8s-master chart]# rm -rf templates/*
[root@k8s-master chart]# echo "" > values.yaml 

创建文件

bash 复制代码
[root@k8s-master chart]# mkdir file
[root@k8s-master chart]# cat file/test.txt 
test

获取文件所有内容

bash 复制代码
[root@k8s-master chart]# cat templates/configmap.yaml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: {{ .Release.Name }}
data:
  file: {{ .Files.Get "file/test.txt" }}

试运行查看结果

bash 复制代码
# Source: chart/templates/configmap.yaml
apiVersion: v1
kind: ConfigMap
metadata:
  name: chart
data:
  file: test

.Files.Lines获取文件内容

逐行遍历文件内容

yaml 复制代码
[root@k8s-master m1]# cat chart/templates/configmap.yaml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: {{ .Release.Name }}
data:
{{- range $index,$line := .Files.Lines "file/test.txt" }}
  {{ if $line }}
  {{ $index }}: {{ $line | quote }}
  {{- end }}
{{- end }}


[root@k8s-master m1]# cat chart/file/test.txt 
test1
test2
test3
test4

试运行结果

yaml 复制代码
# Source: chart/templates/configmap.yaml
apiVersion: v1
kind: ConfigMap
metadata:
  name: chart
data:
  
  0: "test1"
  
  1: "test2"
  
  2: "test3"
  
  3: "test4"

.Files.Glob获取文件路径

bash 复制代码
[root@k8s-master m1]# touch chart/file/test{2..4}.txt
[root@k8s-master m1]# mkdir -p chart/file/file1/test{1..3}.txt

获取文件路径

yaml 复制代码
[root@k8s-master m1]# cat chart/templates/configmap.yaml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: {{ .Release.Name }}
data:
{{- range $path,$content := .Files.Glob "file/*" }}
  {{ $path }}: {{ $content }}
{{- end }}


# 如果只想要路径,可以如下
{{- range $path,$_ := .Files.Glob "file/*" }}
  path: {{ $path }}
{{- end }}

试运行结果

bash 复制代码
# Source: chart/templates/configmap.yaml
apiVersion: v1
kind: ConfigMap
metadata:
  name: chart
data:
  file/test.txt: "test1\ntest2\ntest3\ntest4\n"
  file/test2.txt: ""
  file/test3.txt: ""
  file/test4.txt: ""

学习内容参考:helm3实战

相关推荐
开发者联盟league7 小时前
使用k8s安装Sonarqube
云原生·容器·kubernetes
m0_7381207210 小时前
渗透测试基础——基于Docker的Rsync服务靶场搭建与原理讲解
运维·服务器·网络·安全·web安全·docker·容器
小义_11 小时前
【Ansible】(三)基础配置与连接设置
云原生·ansible
松岩11 小时前
网络问题导致 Pod Pending
kubernetes·aiops
极客先躯15 小时前
高级java每日一道面试题-2026年02月09日-实战篇[Docker]-Docker 容器有哪些安全风险?如何缓解?
java·运维·网络·安全·docker·容器
yuanzhengme15 小时前
Ollama【部署 07】搭建本地智能体的简单说明(局域网离线部署Ollama+模型迁移+Docker部署AnythingLLM)
运维·docker·容器·大模型·ollama·本地智能体
运维老郭16 小时前
Kubernetes 二进制部署完全指南:从零搭建生产级HA集群
运维·云原生·kubernetes
成为你的宁宁16 小时前
【K8S黑盒监控实践:Probe配置、Prometheus验证与Grafana可视化】
kubernetes·grafana·prometheus
成为你的宁宁16 小时前
【Prometheus Operator监控K8S Nginx】
nginx·kubernetes·prometheus
宇明一不急17 小时前
k8s headless svc
云原生·容器·kubernetes