背景:项目deploy需要依赖svc启动,但是k8s启动deploy是无序的,就需要人为控制
讲解了 Init Container 的使用,接下来介绍 Init Container 有哪些应用场景。
在很多的应用场景中,应用在启动之前都需要执行如下初始化操作:
??等待其他关联组件运行(例如:数据库或某个后台服务)。
??基于环境变量(env)或者配置模板生成配置文件。
??从远程数据库获取本地所需的配置信息(类似配置中心),或者将自身注册到某个中央数据库中(类似服务注册)。
??下载相关依赖包,或者对系统进行一些预配置操作。
??应用 Init Container 对集群环境进行故障排查。与其他几种应用场景相比较特殊。
举个例子:
apiVersion: v1
kind: Pod
metadata:
name: myapp-pod
labels:
app.kubernetes.io/name: MyApp
spec:
containers:
- name: myapp-container
image: busybox:1.28
command: ['sh', '-c', 'echo The app is running! && sleep 3600']
initContainers:
- name: init-myservice
image: busybox:1.28
command: ['sh', '-c', "until nslookup myservice.$(cat /var/run/secrets/kubernetes.io/serviceaccount/namespace).svc.cluster.local; do echo waiting for myservice; sleep 2; done"]
- name: init-mydb
image: busybox:1.28
command: ['sh', '-c', "until nslookup mydb.$(cat /var/run/secrets/kubernetes.io/serviceaccount/namespace).svc.cluster.local; do echo waiting for mydb; sleep 2; done"]
接下来就要实现检测svc是否正常使用的脚本
? ?server_check.sh
addr="$1"
port="$2"
while true; do
telnet_output="$( sleep 1; echo $'\e';telnet $addr $port 2>&1)"
result=$(echo $telnet_output | grep "refused")
echo $result
if [[ "$result" != "" ]]
then
echo "connection refused, sleep 2 seconds, retry"
sleep 2
else
echo "sucess"
exit 0
fi
done
sh server_check.sh svc_name svc_port
结论:将检测svc的脚本挂在到上面的initcontainers中,在conmmand中执行即可