0

我正在尝试创建一个RoleRoleBinding所以我可以使用 Helm。{{namespace}}我想在运行apply命令时以某种方式使用变量替换来替换某些东西。

kind: Role
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: tiller-manager-{{namespace}}
  namespace: {{namespace}}
rules:
- apiGroups: ["", "batch", "extensions", "apps"]
  resources: ["*"]
  verbs: ["*"]

我想通过命名空间是这样的:

kubectl apply --file role.yaml --namespace foo

我已经看到它kubectl apply有一个--template参数,但我看不到太多关于如何使用它的信息。

4

3 回答 3

5

您可以通过以下方式进行操作。

  1. 像这样写Role文件:

    kind: Role
    apiVersion: rbac.authorization.k8s.io/v1
    metadata:
      name: tiller-manager-${NAMESPACE}
      namespace: ${NAMESPACE}
    rules:
    - apiGroups: ["", "batch", "extensions", "apps"]
      resources: ["*"]
      verbs: ["*"]
    
  2. NAMESPACE环境变量设置为您想要的值。

  3. 然后使用以下命令创建角色

    envsubst < role.yaml | kubectl apply -f -
    
于 2018-11-13T17:00:36.857 回答
1

您可以使用的另一种方式。使用sed命令可以{{namespace}}直接替换。无需设置任何环境变量或使用envsubst.

  1. 首先将您的角色保存在role.yaml包含原始内容的文件中。
  2. 然后使用sed 's/{{namespace}}/your-namespace-name/g' role.yaml. stdout在所需文件中打印。替换{{namespace}}your-namespace-name

注意:您也可以使用将其保存在文件中sed 's/{{namespace}}/your-namespace-name/g' role.yaml > new-role.yaml

于 2018-11-15T06:40:04.817 回答
0

可以这样做。

cat .env
IMAGE_SOURCE=hello
IMAGE_VERSION=2.3.4

源.env;自定义构建开发 | envsubst

于 2020-10-13T11:39:58.763 回答