k8s---容器探针

apiVersion: v1
kind: Pod
metadata:
  labels:
    run: nginx2
  name: nginx2
spec:
  containers:
  - image: centos:7
    name: nginx2
    command: ["/bin/bash","-c","sleep 3600"]
    readinessProbe:
      exec:
        command: ["/usr/bin/test","-e","/etc/passwd"]
      initialDelaySeconds: 4
      periodSeconds: 2

因为-c是查看字符串,但/usr/bin/test和/etc/passwd是文件,所以readinessProbe探针探测不到

改成-e即可

apiVersion: v1
kind: Pod
metadata:
  labels:
    run: nginx1
  name: nginx1
spec:
  containers:
  - image: tomcat:8.0.52
    name: nginx1
    readinessProbe:
      httpGet:
        scheme: HTTP
        port: 8080
        path: /index.jsp
      initialDelaySeconds: 4
      periodSeconds: 2

readinessProbe

就绪探针,pod的状态是running ,ready是notready

存活探针和就绪探针会伴随整个容器的生命周期

启动探针

apiVersion: v1
kind: Pod
metadata:
  labels:
    run: nginx1
  name: nginx1
spec:
  containers:
  - image: tomcat:8.0.52
    name: nginx1
    startupProbe:
      tcpSocket:
        port: 8081
      initialDelaySeconds: 4
      periodSeconds: 2

端口不正确,所以启动探针探测出错误

改成8080

启动探针没有成功之前,后续的探针都不会执行

启动探针成功之后,在pod的生命周期内不会再检测启动探针

容器启动和退出的动作

postpre:容器启动钩子。容器启动之后触发的条件

prestop:容器退出的钩子,容器推出之后触发的条件。

 volumeMounts:
      - name: test1
        mountPath: /opt
        readOnly: false
声明容器内部的挂载目录
要给这个挂载卷取名字,不同的挂载卷的名字不能重复
readOnly: false: 可读写


  volumes:
  - name: test1
    hostPath:
      path: /opt/test
      type: DirectoryOrCreate
声明的是node节点上和容器内的/opt的挂载目录
挂载卷的名称和要挂载的容器内挂载卷名称要一一对应
hostPath:指定和容器的挂载目录
type: DirectoryOrCreate:如果节点上的目录不存在,自动创建该目录。

pod会经常被重启,销毁,一旦容器和node节点做了挂载卷,数据不会丢失

启动和退出的作用
1.启动可以自动逸配置容器内的环境变量
2.通知机制,告诉用户容器启动完毕
3.退出时,可以执行自定义命令,删除或者生成一些必要的程序,

apiVersion: v1
kind: Pod
metadata:
  name: nginx3
spec:
  containers:
    - name: nginx3
      image: centos:7
      command: ["/bin/bash", "-c", "sleep 3600"]
      volumeMounts:
      - name: test1
        mountPath: /opt
        readOnly: false
      lifecycle:
        postStart:
          exec:
            command: ["/bin/bash","-c","echo hello from start >> /opt/123.txt ; sleep 10"]
        preStop:
          exec:
            command: ["/bin/bash","-c","echo hello from stop >> /opt/123.txt"]
  volumes:
  - name: test1
    hostPath:
      path: /opt/test
      type: DirectoryOrCreate

在这个pod的生命周期时间当中,把启动探针,就绪探针,,存活探针,加入到容器的生命周期内。

apiVersion: v1
kind: Pod
metadata:
  name: nginx3
spec:
  containers:
    - name: nginx3
      image: tomcat:8.0.52
      volumeMounts:
      - name: test1
        mountPath: /opt
        readOnly: false
      lifecycle:
        postStart:
          exec:
            command: ["/bin/bash","-c","echo hello from start >> /opt/123.txt ; sleep 10"]
        preStop:
          exec:
            command: ["/bin/bash","-c","echo hello from stop >> /opt/123.txt"]
      startupProbe:
        exec:
          command: ["/usr/bin/test","-e","/etc/passwd"]
        initialDelaySeconds: 4
        periodSeconds: 2
      livenessProbe:
        httpGet:
          scheme: HTTP
          port: 8080
          path: /index.jsp
        initialDelaySeconds: 4
        periodSeconds: 2
      readinessProbe:
        httpGet:
          scheme: HTTP
          port: 8080
          path: /index.jsp
        initialDelaySeconds: 4
        periodSeconds: 2

  volumes:
  - name: test1
    hostPath:
      path: /opt/test
      type: DirectoryOrCreate

pod的重启策略:

在k8s当中都是重启pod

Always:默认策略--》当pod内的容器退出,不论是一个还是两个容器退出,整个pod都会重启

never:当pod内的容器退出时,退出一个还是退出N个,pod都不重启。

Onfailure:当pod内的容器退出时,状态码0,整个pod都不会重启,只有一个或者N个容器非正常退出,状态码非0,整个pod才会重启。

k8s就是集群化管理容器