文档解读 | K8S中的Pod和容器配置(一)

简介: 如何给运行在Kubernetes(K8S) Pod中的容器定义环境变量、命令行和参数? 给运行在Kubernetes Pod中的容器定义环境变量 开始之前 必须有一个Kubernets集群,和一个能和集群沟通的kubectl命令行工具。

如何给运行在Kubernetes(K8S) Pod中的容器定义环境变量、命令行和参数?   

给运行在Kubernetes Pod中的容器定义环境变量

开始之前

必须有一个Kubernets集群,和一个能和集群沟通的kubectl命令行工具。如果你还没有集群,你可以用Minikube建立一个集群。

给容器定义环境变量

当你建立了一个Pod,你可以给你运行在Pod中的容器设置环境变量。设置环境变量包含两个字段env和envFrom在配置文件中。

在本次练习中,建了一个运行了一个container的Pod。这个配置文件给这个Pod定义了一个名为DEMO_GREETING值为”Hello from the environment”的环境变量。下面是这个Pod的配置文件:

apiVersion: v1

kind: Pod

metadata:

name: envar-demo

labels:

purpose: demonstrate-envars

spec:

containers:

– name: envar-demo-container

image: gcr.io/google-samples/node-hello:1.0

env:

– name: DEMO_GREETING

value: “Hello from the environment”

1.新建一个Pod基于YAML配置文件:

kubectl create -f http://k8s.io/docs/tasks/configure-pod-container/envars.yaml


2.运行Pod的列表:

kubectl get pods -l purpose=demonstrate-envars

3.获取一个shell到Pod运行的容器里:

kubectl exec -it envar-demo — /bin/bash

4.在shell里,运行printenv命令列出环境变量

root@envar-demo:/# printenv

输出类似于下面:

NODE_VERSION=4.4.2

EXAMPLE_SERVICE_PORT_8080_TCP_ADDR=10.3.245.237

HOSTNAME=envar-demo

DEMO_GREETING=Hello from the environment

5.退出shell,输入exit。

给运行在Kubernetes Pod中的容器定义命令行和参数

开始之前

必须有一个Kubernets集群,和一个能和集群沟通的kubectl命令行工具。如果你还没有集群,你可以用Minikube建立一个集群。

新建Pod的时候定义命令行和参数

创建Pod的时候,可以为运行在里面的容器定义一个命令行和参数。定义一个命令行,在配置文件中包含command字段。给这个命令行定义参数包含一个args字段在配置文件中。当Pod创建之后该命令行和参数是不可以修改的。

如果在配置文件中定义了命令行和参数,将覆盖容器镜像提供的默认参数。如果定义了参数但是没有定义命令行,那么参数将和默认的命令行一起使用。更多详细信息可以参考Commands and Capabilities。

在本次练习中,创建一个运行一个容器的Pod。下面Pod的配置文件定义了一个命令行和两个参数。

apiVersion: v1

kind: Pod

metadata:

name: command-demo

labels:

purpose: demonstrate-command

spec:

containers:

– name: command-demo-container

image: debian

command: [“printenv”]

args: [“HOSTNAME”, “KUBERNETES_PORT”]

1.创建Pod基于YAML配置文件:

kubectl create -f http://k8s.io/docs/tasks/configure-pod-container/commands.yaml

2.获取运行中的Pod列表:

kubectl get pods

输出显示在command-demo Pod中运行的容器已完成。

3.查看命令行在容器里面的输出,可以查看Pod的日志:

kubectl logs command-demo

输出展示了HOSTNAME,KUBERNETES_ROOT的环境变量的值:

command-demo

tcp://10.3.240.1:443

使用环境变量定义命令行参数

在前面的例子中,直接通过字符串定义了命令行参数。作为直接用字符串替代方法,你可以用环境变量定义参数:

env:

– name: MESSAGE

value: “hello world”

command: [“/bin/echo”]

args: [“$(MESSAGE)”]

这意味着你可以使用可用于定义环境变量的任何技术来定义Pod的参数,包括ConfigMaps 和 Secrets。

注意:环境变量呈现在括号中,”$(VAR)”。这是在command或args字段中扩展变量所必须的。

在shell中运行命令行

在一些情况,你需要在shell中运行你的命令。例如:你的命令可能是由多个命令组合在一起,或者是一个shell脚本。要在shell中运行你的命令,可以这样包装它:

command: [“/bin/sh”]

args: [“-c”, “while true; do echo hello; sleep 10;done”]

本文转移K8S技术社区-文档解读 | K8S中的Pod和容器配置(一)

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
16天前
|
前端开发 编解码 数据格式
浅谈响应式编程在企业级前端应用 UI 开发中的实践
浅谈响应式编程在企业级前端应用 UI 开发中的实践
17 0
浅谈响应式编程在企业级前端应用 UI 开发中的实践
|
29天前
|
缓存 Kubernetes Docker
容器服务ACK常见问题之容器服务ACK ingress websocket配置失败如何解决
容器服务ACK(阿里云容器服务 Kubernetes 版)是阿里云提供的一种托管式Kubernetes服务,帮助用户轻松使用Kubernetes进行应用部署、管理和扩展。本汇总收集了容器服务ACK使用中的常见问题及答案,包括集群管理、应用部署、服务访问、网络配置、存储使用、安全保障等方面,旨在帮助用户快速解决使用过程中遇到的难题,提升容器管理和运维效率。
|
18天前
|
Kubernetes 容器
k8s容器时间与服务器时间不一致问题
k8s容器时间与服务器时间不一致问题
17 0
|
7天前
|
JSON Kubernetes Go
无缝集成:在IntelliJ IDEA中利用Kubernetes插件轻松管理容器化应用
无缝集成:在IntelliJ IDEA中利用Kubernetes插件轻松管理容器化应用
17 0
无缝集成:在IntelliJ IDEA中利用Kubernetes插件轻松管理容器化应用
|
7天前
|
存储 Kubernetes 调度
Kubernetes Pod生命周期
Kubernetes Pod生命周期
12 0
Kubernetes Pod生命周期
|
7天前
|
存储 Kubernetes 应用服务中间件
Kubernetes Pod
Kubernetes Pod
30 0
Kubernetes Pod
|
18天前
|
存储 Kubernetes 调度
K8s Pod亲和性、污点、容忍度、生命周期与健康探测详解(下)
本文全面探讨了Kubernetes集群中Pod的四种关键机制——Pod亲和性、污点(Taints)、容忍度(Tolerations)、生命周期以及健康探测,为读者提供了深入理解并有效应用这些特性的指南。
|
18天前
|
Kubernetes 网络协议 Perl
k8s Failed to create pod sandbox: open /run/systemd/resolve/resolv.conf: no such file or directory
k8s Failed to create pod sandbox: open /run/systemd/resolve/resolv.conf: no such file or directory
20 0
|
21天前
|
Kubernetes API 调度
总结归纳Kubernetes | 一站式速查知识,助您轻松驾驭容器编排技术(水平扩展控制)
总结归纳Kubernetes | 一站式速查知识,助您轻松驾驭容器编排技术(水平扩展控制)
45 0
|
26天前
|
Kubernetes Nacos 微服务
nacos常见问题之v2.2.3 k8s 微服务注册nacos强制删除 pod不消失如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
22 1
nacos常见问题之v2.2.3 k8s 微服务注册nacos强制删除 pod不消失如何解决