如何使用“ kubectl补丁--type ='json'”更新机密

时间:2019-04-18 10:57:20

标签: kubernetes kubectl kubernetes-secrets

我创建了这样一个秘密:

kubectl create secret generic test --from-literal=username=testuser --from-literal=password=12345

我想将用户名更新为testuser2,但我只想用kubectl patch --type='json'来做。

这是我尝试执行的操作:

kubectl patch secret test --type='json' -p='[{"data":{"username": "testuser 2"}}]' -v=1  

但是我收到了:

  

“”无效

请记住,我想使用--type='json'选项,没有其他解决方法。

1 个答案:

答案 0 :(得分:1)

在我读了here很棒的文章this之后,我发现了如何做。
这是JSON机密:

{
    "apiVersion": "v1",
    "data": {
        "password": "aWx1dnRlc3Rz",
        "username": "dGVzdHVzZXI="
    },
    "kind": "Secret",
    "metadata": {
        "creationTimestamp": "2019-04-18T11:37:09Z",
        "name": "test",
        "namespace": "default",
        "resourceVersion": "3017",
        "selfLink": "/api/v1/namespaces/default/secrets/test",
        "uid": "4d0a763e-61ce-11e9-92b6-0242ac110015"
    },
    "type": "Opaque"
}

因此,要更新用户字段,我需要创建JSON补丁格式:

[
    {
        "op" : "replace" ,
        "path" : "/data/username" ,
        "value" : "dGVzdHVzZXIy" # testuser2 in base64
    }
]

请注意,该值应位于base64中。

结果是:

kubectl patch secret test --type='json' -p='[{"op" : "replace" ,"path" : "/data/username" ,"value" : "dGVzdHVzZXIy"}]'