本文主要是介绍k8s学习(六) 使用pod hook,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Pod Hook 是由 kubelet 发起的,当容器中的进程启动前或者容器中的进程终止之前运行,这是包含在容器的生命周期之中。我们可以同时为 Pod 中的所有容器都配置 hook。
Kubernetes 为我们提供了两种钩子函数:
PostStart:这个钩子在容器创建后立即执行。但是,并不能保证钩子将在容器ENTRYPOINT之前运行,因为没有参数传递给处理程序。主要用于资源部署、环境准备等。不过需要注意的是如果钩子花费太长时间以至于不能运行或者挂起, 容器将不能达到running状态。
PreStop:这个钩子在容器终止之前立即被调用。它是阻塞的,意味着它是同步的, 所以它必须在删除容器的调用发出之前完成。主要用于优雅关闭应用程序、通知其他系统等。如果钩子在执行期间挂起, Pod阶段将停留在running状态并且永不会达到failed状态。
如果PostStart或者PreStop钩子失败, 它会杀死容器。所以我们应该让钩子函数尽可能的轻量。当然有些情况下,长时间运行命令是合理的, 比如在停止容器之前预先保存状态。
有两种方式来实现上面的钩子函数:
Exec - 用于执行一段特定的命令,不过要注意的是该命令消耗的资源会被计入容器。
HTTP - 对容器上的特定的端点执行HTTP请求。
1、使用exec方式实现钩子函数
创建hook-demo1.yaml
apiVersion: v1
kind: Pod
metadata:name: hook-demo1
spec:containers:- name: hook-demo1image: 172.16.10.190:8008/helloworld:0.0.4lifecycle:postStart:exec:command: ["/bin/sh", "-c", "echo Hello from the postStart handler -> /usr/share/message"]preStop:exec:command: ["/bin/sh", "-c", "echo Hello from the preStop handler -> /usr/share/message"]ports:- containerPort: 8080imagePullSecrets:- name: myregistrykey6
使用exec执行命令,将一段话输出到/usr/share/message中
kubectl create -f hook-demo1.yaml
注意的是输出的内容在容器内部
进入pod内部的方法
kubectl exec -ti <your-pod-name> -n <your-namespace> -- /bin/sh
2、使用http方式实现钩子函数
使用HttpGet配置host、path、port,容器启动的时候会调用这个url
apiVersion: v1
kind: Pod
metadata:name: hook-demo1
spec:containers:- name: hook-demo1image: 172.16.10.190:8008/helloworld:0.0.5lifecycle:postStart:httpGet:host: 192.168.100.88path: indexport: 8080
# exec:
# command: ["/bin/sh", "-c", "echo Hello from the postStart handler -> /usr/share/message"]preStop:exec:command: ["/bin/sh", "-c", "echo Hello from the preStop handler -> /usr/share/message"]ports:- containerPort: 8080imagePullSecrets:- name: myregistrykey6
kubectl create -f hook-demo1.yaml
pod启动前会发现调用了要访问的接口
这篇关于k8s学习(六) 使用pod hook的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!