kubernetes 容器运行应用对应字段

pod运行应用对应字段

常用字段总结

  • initContainers
  • hostAliases
  • imagePullSecrets
  • affinity
  • nodeName
  • nodeSelector
  • tolerations
  • hostNetwork
  • containers
  • restartPolicy
  • dnsPolicy
  • imagePullPolicy
  • ports
  • volumeMounts
  • volumes
  • securityContext
  • startupProbe
  • livenessProbe
  • readinessProbe
  • resources
  • lifecycle
  • workingDir
  • command
  • args
  • env
  • envFrom

容器镜像拉取策略

imagePullPolicy: 容器的镜像拉取策略

  • IfNotPresent 本地有镜像则使用本地镜像 本地不存在则拉取镜像
  • Always 每次都会尝试拉取策略
  • Never: 永不拉取 如果镜像已经存在本地 kubelet 会尝试启动容器, 否则会启动失败

案例

apiVersion: v1
kind: Pod
metadata:
  name: default-pod
  namespace: default
spec:
    containers:
  - name: nginx
    image: nginx
    imagePullPolicy: IfNotPresent
    ports:
    - containerPort: 80

如果你省略了 imagePullPolicy 字段,并且容器镜像的标签是:latest, imagePullPolicy 会⾃动设置为 Always。如果你省略了 imagePullPolicy 字段,并且没有指定容器镜像的标签,imagePullPolicy 会⾃动设置为 Always。 如果你省略了imagePullPolicy 字段,并且为容器镜像指定了⾮ :latest 的标签, imagePullPolicy 就会⾃动设置为 IfNotPresent。

获取私有仓库镜像

ImagePullSecrets 拉取私有仓库中的镜像
创建一个仓库认证的secret

kubectl create secret docker-
registry aliyun !"docker-username=123qq.com -
-docker-password=123456 !"docker-server registry.cn-
huhehaote.aliyuncs.com

案例

apiVersion: v1
kind: Pod
metadata:
  name: default-pod
  namespace: default
spec:
  imagePullSecrets:
  - name: aliyun
  containers:
  - name: nginx
    image: nginx
    imagePullPolicy: IfNotPresent
    ports:
    - containerPort: 80

env 为容器内部传递变量

基本实例

apiVersion: v1
kind: Pod
metadata:
  name: default-pod
  namespace: default
spec:
  containers:
  - name: nginx
    image: nginx
    imagePullPolicy: IfNotPresent
    env:
    - name: pod_name
      value: "default-pod"
    ports:
    - containerPort: 80

改变容器的启动命令 command & args

基本示例

apiVersion: v1
kind: Pod
metadata:
  name: default-pod
  namespace: default
spec:
  containers:
  - name: nginx
    image: nginx
    imagePullPolicy: IfNotPresent
    command:
    - /bin/bash
    args:
    - -c
    - sleep 10 ; echo success > /root/done.txt
    ports:
    - containerPort: 80

指定容器的工作目录 workingDir

案例

apiVersion: v1
kind: Pod
metadata:
  name: default-pod
  namespace: default
spec:
  containers:
  - name: nginx
    image: nginx
    imagePullPolicy: IfNotPresent
    workingDir: /tmp/
    command:
    - /bin/bash
    args:
    - -c
    - sleep 10 ; echo success > /root/done.txt
    ports:
    - containerPort: 80

服务暴露 ports

ports ⽤于暴露 pod 对外访问的端⼝,如不指定,则⽆法通过PodIP + PodPort 访问该应⽤
containerPort <integer> -required-: 填写Pod对外暴露的端⼝(0~65535)
name <string!' 为端⼝指定⼀个名称,当服务存在多个端⼝,可以通过名称区分;
protocol <string>:指定端⼝对应的协议,有TCP,UDP,SCTP,默认不写为TCP;

应用案例

apiVersion: v1
kind: Deployment
metadata:
  name: default-pod
  namespace: defualt
  labels:
    app: nginx
spec:
  containers:
  - name: nginx
    image: nginx
    imagePullPolicy: IfNotPresent
    ports:
    - name: http
      containerPort: 80
      protocol: TCP

pod重启策略 restartPolicy

Pod 的 spec 中包含⼀个 restartPolicy 字段,⽤来设置 Pod 中所有容器的重启策略,取值有Always、OnFailure、Never。默认值是Always。
Always:当容器出现异常退出时,kubelet 会尝试重启该容器,已恢复正常状态;(默认策略)
Never:当容器退出时,kubelet 永远不会尝试重启该容器(适合Job类⼀次性任务)
OnFailure:当容器异常退出(且退出状态码⾮0时),kubelet会尝试重启容器(适合Job类⼀次性任务)

应用案例

apiVersion: v1
kind: Deployment
metadata:
  name: default-pod
  namespace: defualt
  labels:
    app: nginx
spec:
  restartPolicy: Always
  containers:
  - name: nginx
    image: nginx
    imagePullPolicy: IfNotPresent
    ports:
    - name: http
      containerPort: 80

探针配置规范

spec:
  containers:
  - name: ...
    image: ...
    livenessProbe:
      exec <0bject>     #命令式探针
      httpGet <0bject>  #httpGET类型的探针
      tcpSocket <0bject>  #tcp Socket类型的探针 I
      initialDelaySeconds <integer> #发起初次探测请求的延后时长
      periodSeconds <integer>  #请求周期
      timeoutSeconds <integer> #超时时长
      successThreshold <integer>  #成功阈值
      failureThreshold <integer>  #失败阈值

案例

[root@k8s-master Probe]# cat liveness-exec-damo.yaml 
apiVersion: v1
kind: Pod
metadata:
  name: liveness-exec-demo
  namespace: default
spec:
  containers:
  - name: demo
    image: ikubernetes/demoapp:v1.0
    imagePullPolicy: IfNotPresent
    livenessProbe:
      exec:
        command: ['/bin/sh','-c','[ "$(curl -s 127.0.0.1/livez)" == "OK" ]']
      initialDelaySeconds: 5  #初始化等待时间5秒后探测
      timeoutSeconds: 1   #超时时间
      periodSeconds: 5   #每隔5秒探测一次

$ kubectl apply -f liveness-exec-damo.yaml
$ kubectl get pod  -o wide
NAME                                READY   STATUS            RESTARTS   AGE     IP              NODE        NOMINATED NODE   READINESS GATES
...
liveness-exec-demo                  1/1     Running           0          76s     10.244.2.84     k8s-node2   <none>           <none>
...

$ curl 10.244.2.84:/livez
OK

$ curl -X POST -d 'livez=FAIL' 10.244.2.84:/livez      #能过POST修改livez值
$ curl 10.244.2.84:/livez
FAIL
$ kubectl describe pod liveness-exec-demo
...
Events:
  Type     Reason     Age                  From               Message
  ----     ------     ----                 ----               -------
  Normal   Scheduled  7m38s                default-scheduler  Successfully assigned default/liveness-exec-demo to k8s-node2
  Warning  Unhealthy  89s (x3 over 99s)    kubelet            Liveness probe failed:    #存活检测失败 重启容器
  Normal   Killing    89s                  kubelet            Container demo failed liveness probe, will be restarted
  Normal   Pulled     59s (x2 over 7m33s)  kubelet            Container image "ikubernetes/demoapp:v1.0" already present on machine
  Normal   Created    59s (x2 over 7m33s)  kubelet            Created container demo
  Normal   Started    59s (x2 over 7m33s)  kubelet            Started container demo


$ kubectl get pod  -o wide
NAME                                READY   STATUS            RESTARTS   AGE     IP              NODE        NOMINATED NODE   READINESS GATES
...
liveness-exec-demo                  1/1     Running           1          9m15s   10.244.2.84     k8s-node2   <none>           <none>    #显示容器已重启
...

容器内部调试工具

用于记录下k8s集群中用于调试dns及网络连通性的容器工具。此工具提供了基本的网络排查指令,如curl、wget、ping、traceroute、nslookup、dig。

$ cat dns_utils.yaml      # yaml文件如下
apiVersion: v1
kind: Pod
metadata:
  name: dnsutils
  namespace: default
spec:
  containers:
  - name: dnsutils
    image: mydlqclub/dnsutils:1.3
    command:
      - sleep
      - "3600"
    imagePullPolicy: IfNotPresent
  restartPolicy: Always
  
$ kubectl apply -f dns_utils.yaml     # 执行yaml文件
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容

  • 容器 每个运行的容器都是可重复的; 包含依赖环境在内的标准,意味着无论您在哪里运行它,您都会得到相同的行为。容器将...
    Noperx阅读 207评论 0 0
  • 到这篇文章为止,笔者通过前边6篇文章详细的介绍了容器以及组织容器,进行资源调度的POD对象,由于POD和容器是容器...
    攀师傅阅读 1,277评论 0 0
  • 控制器管理的 Pod: 生产环境中可以用控制器创建和管理多个 pod。控制器在 pod 失败的情况下可以处理副本、...
    菜头_355f阅读 558评论 0 1
  • Kubernetes 简介 Kubernetes 是什么? Kubernetes 是一个可移植的、可扩展的开源平台...
    王勇1024阅读 709评论 0 2
  • API server 接受和返回的所有 JSON 对象都遵循同一个模式,它们都具有 "kind" 和 "apiVe...
    强出头阅读 1,371评论 0 0