首页 > 解决方案 > 如何在 Kubernetes 中找到分配给 V1ObjectMeta 的名称是什么?

问题描述

我使用 k8s python 客户端有以下代码:

config.load_incluster_config()
v1 = client.CoreV1Api()
object_meta = k8s.V1ObjectMeta(generate_name='myprefix',
                               namespace='my_name_space')
body = k8s.V1Secret(string_data=data, kind='Secret', type='my_type', metadata=object_meta)
api_response = v1.create_namespaced_secret(namespace='my_name_space', body=body)

这会在我的 K8s 命名空间中创建一个秘密。由于我使用的是 generate_name,它为它分配了一些带有前缀的随机值,因此名称可以是myprefix-fbdsu3或类似的名称。

我的问题是如何在创建后获得分配给该秘密的名称?

标签: pythonkubernetes

解决方案


您可以将秘密名称传递到此代码中并获取秘密的示例

from kubernetes import client, config
config.load_kube_config()
v1 = client.CoreV1Api()
secret = v1.read_namespaced_secret("Secret-name", "Namespace-Name")
print(secret)

解码秘密并获取详细信息

from kubernetes import client, config
import base64
import sys    
config.load_kube_config()
v1 = client.CoreV1Api()
sec = str(v1.read_namespaced_secret("secret-name", "namespace-name").data)
pas = base64.b64decode(sec.strip().split()[1].translate(None, '}\''))
print(pas)

阅读更多:https ://www.programcreek.com/python/?CodeExample=create+secret


推荐阅读