在K8S中挂载 Secret 到 Pod

在 Kubernetes 里,把 Secret 挂载到 Pod 中有两种主要方式:作为卷挂载和作为环境变量挂载。下面为你提供相应的代码示例。

作为卷挂载 Secret

将 Secret 作为卷挂载到 Pod 时,Secret 的每个键会成为挂载目录下的一个文件,文件内容就是键对应的值。

以下是一个示例 YAML 文件,展示了如何把 Secret 作为卷挂载到 Pod 中:

yaml 复制代码
apiVersion: v1
kind: Pod
metadata:
  name: secret-volume-pod
spec:
  containers:
    - name: my-container
      image: nginx
      volumeMounts:
        - name: secret-volume
          mountPath: "/etc/secret"
          readOnly: true
  volumes:
    - name: secret-volume
      secret:
        secretName: my-secret    
代码解释
  • volumeMounts:定义了容器内的挂载点,这里是 /etc/secret 目录,并且设置为只读。
  • volumes:定义了要挂载的卷,secretName 指定了要使用的 Secret 的名称。

作为环境变量挂载 Secret

把 Secret 作为环境变量挂载到 Pod 时,Secret 的键值对会成为容器的环境变量。

以下是一个示例 YAML 文件,展示了如何将 Secret 作为环境变量挂载到 Pod 中:

yaml 复制代码
apiVersion: v1
kind: Pod
metadata:
  name: secret-env-pod
spec:
  containers:
    - name: my-container
      image: nginx
      env:
        - name: SECRET_USERNAME
          valueFrom:
            secretKeyRef:
              name: my-secret
              key: username
        - name: SECRET_PASSWORD
          valueFrom:
            secretKeyRef:
              name: my-secret
              key: password    
代码解释
  • env:定义了容器的环境变量。
  • valueFrom:指定了环境变量的值来源,secretKeyRef 用于引用 Secret 中的键值对。

前提条件

在使用上述配置之前,你需要确保 my-secret 这个 Secret 已经存在于相应的命名空间中。可以使用以下命令创建一个简单的 Secret:

bash 复制代码
kubectl create secret generic my-secret --from-literal=username=admin --from-literal=password=password123

创建好 Secret 后,使用 kubectl apply -f <filename>.yaml 命令来创建 Pod。

相关推荐
YongCheng_Liang1 小时前
【探索实战】Kurator・云原生实战派:从环境搭建到企业落地的全维度实践
云原生
初学者,亦行者1 小时前
【探索实战】从 30 分钟搭建到生产落地,分布式云原生管理新范式
分布式·云原生
喜欢你,还有大家5 小时前
k8s集群监控的部署
云原生·容器·kubernetes
BD_Marathon6 小时前
【Zookeeper】 Zookeeper入门
分布式·zookeeper·云原生
喜欢你,还有大家7 小时前
实战演练——wordpress-k8s集群版
云原生·容器·kubernetes
e***87707 小时前
Node.js 与 Docker 深度整合:轻松部署与管理 Node.js 应用
docker·容器·node.js
csdn_aspnet8 小时前
【探索实战】Kurator入门体验与分布式云原生环境搭建
分布式·云原生·kurator
q***71019 小时前
从零到上线:Node.js 项目的完整部署流程(包含 Docker 和 CICD)
docker·容器·node.js
起风了___10 小时前
Jenkins + Kubernetes 多模块微服务一键流水线:从 Maven 打包到滚动发布完整脚本
kubernetes·jenkins
BD_Marathon11 小时前
【Zookeeper】zk_客户端API_创建节点
分布式·zookeeper·云原生