我有以下配置文件(为简洁起见进行了编辑(:
apiVersion: eksctl.io/v1alpha5
kind: ClusterConfig
metadata:
name: FOO-CLUSTER
region: eu-central-1
nodeGroups:
- name: FOO-CLUSTER-group-1
[..]
- name: FOO-CLUSTER-group-2
[..]
其将用于创建具有CCD_ 1的集群。
我希望避免对集群名称(即本例中的FOO-CLUSTER
(进行硬编码,并将其提取为参数(例如环境变量或附加文件或CLI参数(,以便以后可以使用相同的文件创建BAR-CLUSTER
、FEE-CLUSTER
等。
有可能吗?
我认为这是不可能的。但是,您可以使用该文件作为模板,并在运行命令之前sed
它。对于kubectl apply
,我使用了这种技术,效果很好。您甚至可以使用变量。例如:
template=`curl -sS https://raw.githubusercontent.com/kubernetes-sigs/aws-alb-ingress-controller/v1.1.4/docs/examples/alb-ingress-controller.yaml | sed -e "s/# - --cluster-name=devCluster/- --cluster-name=$CLUSTER_NAME/g" -e "s/# - --aws-vpc-id=vpc-xxxxxx/- --aws-vpc-id=$VPC_ID/g" -e "s/# - --aws-region=us-west-1/- --aws-region=$AWS_REGION/g"`
echo "$template" | kubectl apply -f -
我从来没有在eksctl
中使用过这个,但我看不出为什么它不起作用。
以类似的方式,您可以使用envsubst
。
apiVersion: eksctl.io/v1alpha5
kind: ClusterConfig
metadata:
name: ${CLUSTER_NAME}
region: eu-central-1
nodeGroups:
- name: ${CLUSTER_NAME}-group-1
[..]
- name: ${CLUSTER_NAME}-group-2
[..]
export CLUSTER_NAME=foo
cat cluster-config.yml | envsubst '${CLUSTER_NAME}' > cluster-config-foo.yml