在Kubernetes环境中引用变量的方法

在Kubernetes环境中,变量的引用主要通过环境变量和ConfigMaps来实现。这两种方式都可以让你在Pod的定义中引用变量,从而使你的应用更加灵活和可配置。

首先,我们来看看如何使用环境变量。Kubernetes允许你在Pod定义中设置环境变量。这些可以是硬编码值,也可以是其他Kubernetes资源(如其他Pods或Secrets)的值。

例如,在下面的YAML文件中:

复制代码
apiVersion: v1
kind: Pod
metadata:
  name: envar-demo
spec:
  containers:
    - name: envar-demo-container
      image: gcr.io/google-samples/node-hello:1.0
      env:
        - name: DEMO_GREETING   # 环境变量名字 
          valueFrom:
            fieldRef:
              fieldPath : status.podIP   # 引用podIP作为DEMO_GREETING 的值 

上述代码片段创建了一个名为 envar-demo 的pod,并设置了一个名为 DEMO_GREETING 的环境变量,其值从 pod 自身状态信息 status.podIP 中获取。

其次, 我们来看一下ConfigMaps。ConfigMap 是 Kubernetes 提供给我们存储配置信息并供应给 pods 使用的一种资源对象. 定义 ConfigMap 后, 我们就能够将它挂载到 pod 中去.

例如,在下面创建 ConfigMap 的 YAML 文件:

复制代码
apiVersion : v1
kind : ConfigMap
metadata :
  name : game-demo 
data :
  # 属性类似于键值对 
  player_initial_lives: "3"
  ui_properties_file_name: "user-interface.properties"

然后在 Pod 中引用这个 ConfigMap:

复制代码
apiVersion: v1
kind: Pod
metadata:
  name: configmap-demo-pod 
spec:
 containers:
   - name : demo-container 
     image : gcr.io/google-samples/node-hello:1.0  
     envFrom :
       - configMapRef :
           # 引用上面创建的ConfigMap game-demo  
           name : game-demo   

在这个例子中,我们创建了一个名为 game-demo 的ConfigMap,其中包含两个键值对。然后我们在Pod定义中通过 envFromconfigmapRef 引用了这个ConfigMap。结果是Pod内的容器将拥有两个新的环境变量:player_initial_livesui_properties_file_name, 它们的值分别是"3"和"user-interface.properties"。

总结一下,在Kubernetes环境中引用变量主要有两种方式:一种是通过环境变量,另一种是通过ConfigMaps。前者适合于简单、直接地设置和获取值;后者则更适合于存储和管理复杂、多样化的配置信息。

相关推荐
薪火铺子18 小时前
微服务认证方案对比与选型
微服务·云原生·架构
运维全栈笔记19 小时前
K8S部署Redis高可用全攻略:1主2从3哨兵架构实战
redis·docker·云原生·容器·架构·kubernetes·bootstrap
尘世壹俗人19 小时前
使用K8s部署模型
kubernetes
AI攻城狮20 小时前
AI Agent 从上线到删库跑路始末
云原生
AI木马人21 小时前
9.人工智能实战:GPU 服务如何上 Kubernetes?从单机部署到 K8s + NVIDIA Device Plugin + HPA 的生产级改造
人工智能·容器·kubernetes
码点滴1 天前
告别显存焦虑:PagedAttention 如何将大模型吞吐量提升 4 倍?
人工智能·架构·kubernetes·大模型·pagedattention
键盘鼓手苏苏1 天前
Kubernetes 容器安全最佳实践
云原生·kubernetes·k8
Elastic 中国社区官方博客1 天前
Elasticsearch Serverless 中跨项目搜索(CPS)的工作原理
大数据·elasticsearch·搜索引擎·云原生·serverless
键盘鼓手苏苏1 天前
Kubernetes 安全最佳实践
云原生·kubernetes·k8
小妖同学学AI1 天前
云原生AI服务新范式:Jina Serve框架,让多模态大模型落地像搭积木一样简单
人工智能·云原生·jina