在 Golang K8s 客户端中设置 ConfigMapRef 和 SecretRef 以进行部署

问题描述

我已经被这个错误困扰了几个小时,但仍然不知道为什么!

我创建了一个简单的 Configmap 和一个分别名为 config1 和 secret1 的 Secret。 (这些的 Yaml 文件在此存储库中:https://github.com/hoangphanthai/test

之后我创建了一个 Go 文件(上面的 test.go)来创建一个 Statefulset 和一个部署。我希望所有 pod(由 Statefulset 和 Deployment 创建)在它们的 Env 变量中引用这些 Configmap 和 Secret。 除了名称之外,Statefulset 和 Deployment 的元数据和规范是相同的。

然而,只有 Statefulset 成功创建,但 Deployment 成功。错误是“Deployment.apps“d1”无效:spec.template.spec.containers[0].envFrom:无效值:“”:一次不能指定多个字段”

第二次运行,Statefulset和Deployment都没有成功,显示“Failed to continue - runtime error: invalid memory address or nil pointer dereference [signal SIGSEGV:segmentation conflict] 无法将 EXC_BAD_ACCESS 信号传播到目标进程和恐慌(请参阅 https://github.com/go-delve/delve/issues/852) 最后已知的即时堆栈跟踪(goroutine id 1):""

重要的一段代码如下(完整代码在 repo 的 test.go 文件中):

deployment := &appsv1.Deployment{
    ObjectMeta: metav1.ObjectMeta{
        Name: "d1",},Spec: appsv1.DeploymentSpec{
        Replicas: &repNo,Selector: &metav1.LabelSelector{
            MatchLabels: map[string]string{
                "app": "postgres",Template: apiv1.PodTemplateSpec{
            ObjectMeta: metav1.ObjectMeta{
                Labels: map[string]string{
                    "app": "postgres",Spec: apiv1.PodSpec{
                Containers: containerList,}

statefulset := &appsv1.StatefulSet{
    ObjectMeta: metav1.ObjectMeta{
        Name: "s1",Spec: appsv1.StatefulSetSpec{
        Replicas: &repNo,}

起初我认为不可能同时设置 ConfigMapRef 和 SecretRef,但后来我尝试通过 yaml(上面的 dep.yaml)应用部署,这与代码中的完全相同,但它有效。

我也用谷歌搜索过,但不知道如何解决。

如果有人告诉我如何解决这个问题,我将不胜感激。

感谢您的阅读。

解决方法

基于此错误:

Deployment.apps "d1" 无效: spec.template.spec.containers[0].envFrom: 无效值: "": 可能不 一次指定多个字段"

我建议您应该在代码中尝试以下操作。请注意,只为 EnvFromSource 类型指定了一个字段,它是 ConfigMapRef 或 SecretRef,但永远不会同时指定:

        EnvFrom: []apiv1.EnvFromSource{
            apiv1.EnvFromSource {
                ConfigMapRef: &apiv1.ConfigMapEnvSource{
                    LocalObjectReference: apiv1.LocalObjectReference{
                        Name: configMapName,},apiv1.EnvFromSource {
                SecretRef: &apiv1.SecretEnvSource{
                    LocalObjectReference: apiv1.LocalObjectReference{
                        Name: secretName,}

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...