2

我有一个包含三个配置映射的文件,如下所示。

apiVersion: v1
data:
  TEST: "one"
kind: ConfigMap
metadata:
  name: test-config-one
---
apiVersion: v1
data:
  TEST: "two"
kind: ConfigMap
metadata:
  name: test-config-two
---
apiVersion: v1
data:
  TEST: "three"
kind: ConfigMap
metadata:
  name: test-config-three

我试图仅适用test-config-three于集群。我知道我可以把它分解成它自己的文件并运行kubectl apply -f test-config-three.yaml,但是有没有办法做到这一点而不必创建一个新文件?

我希望能够做类似的事情:

cat file.yml | yq <get only test-config-three> | kubectl apply -f -

yq似乎不支持在文件中查找单个资源。我还查看了kubesplit 之类的工具,但它们倾向于将所有资源输出到单独的文件中。

有没有办法在不创建新文件的情况下从包含多个资源的 yaml 文件中隔离和输出单个资源?

更新

感谢@Inian 在下面的回答,我能够让这个完整的命令正常工作。

cat file.yml | yq e 'select(.data.TEST == "three")' - | kubectl apply -f -
4

2 回答 2

3

有两个版本的yq实现,一个在 Python 中,一个在 Go 中,正如我在如何从 Linux shell 脚本中解析 YAML 文件?

使用 Python 版本 - kislyuk/yq

yq -y 'select(.data.TEST == "three")' yaml

Go 版本 - mikefarah/yq

yq e 'select(.data.TEST == "three")' yaml
于 2021-02-01T13:32:46.513 回答
1

如果你有python,你可以尝试以下

export MYFILE=file.yml
export DOC_NUMBER=2

python3 -c "import yaml; print(yaml.dump(list(yaml.safe_load_all(open('"$MYFILE"')))["$DOC_NUMBER"]))" | kubectl apply -f -

yaml.safe_load_all(open('"$MYFILE"'))将 yaml 文件中的所有文档加载到列表中。然后您选择“$DOC_NUMBER”文档,带有["$DOC_NUMBER"].

yaml.dump会将加载的对象转储回 yaml 格式,然后打印出来。

于 2021-01-26T14:28:21.937 回答