k8s-deployment initcontainers提前监测svc可用

背景:项目deploy需要依赖svc启动,但是k8s启动deploy是无序的,就需要人为控制

Init Container 应用场景

讲解了 Init Container 的使用,接下来介绍 Init Container 有哪些应用场景。

在很多的应用场景中,应用在启动之前都需要执行如下初始化操作:

  • • 等待其他关联组件运行(例如:数据库或某个后台服务)。

  • • 基于环境变量(env)或者配置模板生成配置文件。

  • • 从远程数据库获取本地所需的配置信息(类似配置中心),或者将自身注册到某个中央数据库中(类似服务注册)。

  • • 下载相关依赖包,或者对系统进行一些预配置操作。

  • • 应用 Init Container 对集群环境进行故障排查。与其他几种应用场景相比较特殊。

举个例子:

bash 复制代码
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

bash 复制代码
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中执行即可

相关推荐
福大大架构师每日一题11 小时前
22.1 k8s不同role级别的服务发现
容器·kubernetes·服务发现
莹雨潇潇11 小时前
Docker 快速入门(Ubuntu版)
java·前端·docker·容器
weixin_4539650012 小时前
[单master节点k8s部署]30.ceph分布式存储(一)
分布式·ceph·kubernetes
weixin_4539650012 小时前
[单master节点k8s部署]32.ceph分布式存储(三)
分布式·ceph·kubernetes
tangdou36909865512 小时前
1分钟搞懂K8S中的NodeSelector
云原生·容器·kubernetes
Lansonli13 小时前
云原生(四十一) | 阿里云ECS服务器介绍
服务器·阿里云·云原生
Dylanioucn14 小时前
【分布式微服务云原生】掌握分布式缓存:Redis与Memcached的深入解析与实战指南
分布式·缓存·云原生
tangdou36909865515 小时前
Docker系列-5种方案超详细讲解docker数据存储持久化(volume,bind mounts,NFS等)
docker·容器
later_rql15 小时前
k8s-集群部署1
云原生·容器·kubernetes
weixin_4539650017 小时前
[单master节点k8s部署]31.ceph分布式存储(二)
分布式·ceph·kubernetes