文档解读 | K8S中的Pod和容器配置(一)
如何给运行在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和容器配置(一)
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
K8S中如何使用Glusterfs做持久化存储?
本文通过步骤讲解,旨在让读者了解Kubernetes中如何使用持久化存储,对glusterfs的配置相对简单,不建议在生产环境下使用。 集群详情 Kubernetes 1.6.0 Docker 1.12.5(使用yum安装) Etcd 3.1.5 Flanneld 0.7 vxlan 网络 TLS 认证通信 (所有组件,如 etcd、kubernetes master 和 node) RBAC 授权 kublet TLS BootStrapping kubedns、dashboard、heapster(influxdb、grafana)、EFK(elasticsearch、fluentd、kibana) 集群插件 私有docker镜像仓库harbor(请自行部署,harbor提供离线安装包,直接使用docker-compose启动即可) 以下步骤参考自:https://www.xf80.com/2017/04/21/kubernetes-glusterfs/ 安装Glusterfs 我们直接在物理机上使用yum安装,如果你选择在kubernetes上安装,请参考:https://gi...
- 下一篇
文档解读 | K8S中的Pod和容器配置(二)
接上篇,如何给运行在Kubernetes Pod中的容器分配CPU和RAM资源? 给运行在Kubernetes Pod中的容器分配CPU和RAM资源 开始之前 必须有一个Kubernetes集群,和一个能和集群沟通的kubectl命令行工具。如果你还没有集群,你可以用Minikube建立一个集群。 给容器分配CPU和RAM资源 当创建一个Pod的时候,你可以为运行在Pod中的容器请求CPU和RAM资源。你还可以设置CPU和RAM资源的限制。请求CPU和RAM资源,在配置文件里面包含resources:rquests字段。设置CPU和RAM限制包含resource:limits字段。如果节点上具有足够的CPU和RAM资源可用于所有容器要求的CPU和RAM总和,Kubernetes将把Pod调度在上面。同样当容器运行在节点上时,Kubernetes不允许容器消耗的CPU和RAM资源超出指定的容器的限制。如果容器超出他的RAM限制,他将结束。如果CPU超出限制,他将成为CPU节流的候选者。 在本次练习,创建一个运行了一个容器的Pod。Pod的配置文件请求250milicpu和64 mebi...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS6,CentOS7官方镜像安装Oracle11G
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS8编译安装MySQL8.0.19
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Windows10,CentOS7,CentOS8安装Nodejs环境
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7