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

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

在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。前者适合于简单、直接地设置和获取值;后者则更适合于存储和管理复杂、多样化的配置信息。

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
7月前
|
搜索推荐 物联网 定位技术
IP定位技术的功能和服务概述
总结而言,虽然不能达到GPS那样精确度但是基于成本效益考虑,在多种场景下都证明了其价值。随着移动计算、物联网(IoT)及普适计算领域快速扩张将进一步推动相关研究进步使得未来几年内我们预见会有更加精确便捷高效普适解决方案面市满足日益增长需求。
893 16
|
域名解析 缓存 弹性计算
CDN 的操作与使用|学习笔记
快速学习 CDN 的操作与使用
CDN 的操作与使用|学习笔记
|
4月前
|
消息中间件 分布式计算 大数据
别让数据平台“盲开车”:可观测性三件套(指标、日志、追踪)到底怎么落地?
别让数据平台“盲开车”:可观测性三件套(指标、日志、追踪)到底怎么落地?
222 3
|
7月前
|
消息中间件 Java Kafka
搭建ELK日志收集,保姆级教程
本文介绍了分布式日志采集的背景及ELK与Kafka的整合应用。传统多服务器环境下,日志查询效率低下,因此需要集中化日志管理。ELK(Elasticsearch、Logstash、Kibana)应运而生,但单独使用ELK在性能上存在瓶颈,故结合Kafka实现高效的日志采集与处理。文章还详细讲解了基于Docker Compose构建ELK+Kafka环境的方法、验证步骤,以及如何在Spring Boot项目中整合ELK+Kafka,并通过Logback配置实现日志的采集与展示。
1220 64
搭建ELK日志收集,保姆级教程
|
7月前
|
数据采集 JSON 自然语言处理
超越传统XPath:用LLM理解复杂网页信息
本文深入探讨网页信息抽取技术的演进,从传统 XPath/CSS 结构匹配,到结合 LLM(大语言模型)的语义理解方法。分析了旧技术在动态渲染、结构变化和语义识别方面的局限,并通过架构图、实验数据和示例代码展示 LLM 在新闻、电商、社交等复杂场景中的高效应用。同时强调爬虫代理等基础设施的重要性,为信息抓取提供稳定网络环境。
286 1
超越传统XPath:用LLM理解复杂网页信息
|
7月前
|
监控 关系型数据库 数据库
解析pg_stat_replication状态字段的枚举值
每种枚举值都代表着不同阶段下从属节点(replica)所处环境及其行为模式,在管理和监控PostgreSQL高可用性集群环境中具有重要意义。通过理解每一种枚举值所代表含义可以帮助管理员更好地诊断问题、优化性能以及保证数据一致性等方面提供支持。
198 16
|
8月前
|
算法 PHP UED
PHP编程技巧:生成和解析数独游戏
综合以上步骤与代码片段,在PHP环境下实现高效且可靠地生产与求解标准九宫格型号码谜题成为可行之事务。开发者应根据具体需求进一步优化逻辑与性能确保程序运作流畅且用户体验良好。
207 18
|
9月前
|
安全 Linux Shell
使用SCP命令在CentOS 7上向目标服务器传输文件
以上步骤是在CentOS 7系统上使用SCP命令进行文件传输的基础,操作简洁,易于理解。务必在执行命令前确认好各项参数,尤其是目录路径和文件名,以避免不必要的传输错误。
876 17
|
9月前
|
网络协议
UDP通信:解决socket连接关闭后缓冲内容未清除的问题
当处理这类问题时,核心的策略在于清晰地认识到UDP的无连接特性以及可能随之而来的问题,并通过各种机制在应用层进行适当的管理和控制。实际部署时,这些策略的选择和实现应根据具体的应用场景和性能要求来定制。
277 0
|
8月前
|
C语言 Python
使用Math库执行数值计算
总结来说,掌握数值计算是程序设计中不可或缺的一部分,而 `math`库提供的强大功能和易于使用的接口使其成为Python中进行数值计算的重要工具。利用这些工具,可以高效地解决各类数值问题,这对于科研人员、工程师乃至任何需要进行精确数学计算的专业人士而言,都是极其宝贵的。
291 0

热门文章

最新文章

下一篇
开通oss服务