k8s 查看mysql 日志_k8s 使用 Init Container 确保依赖的服务已经启动
k8s 使用 Init Container 確保依賴的服務(wù)已經(jīng)啟動(dòng)
Intro
最近 helm 3 正式發(fā)布了,dotnetcore 3.1 也正式發(fā)布了,最近打算把我的活動(dòng)室預(yù)約項(xiàng)目做一個(gè)升級(jí),項(xiàng)目已經(jīng)升級(jí)到了 dotnetcore 3.1,最近幾天則在準(zhǔn)備把項(xiàng)目打包一個(gè) helm 包,使得想要在 k8s 上部署的童鞋可以更方便的部署,目前已經(jīng)基本完成,本來打算發(fā)布到阿里云的 AppHub 上,但是前幾天更新的 angular client 的 chart 還沒有更新,不知道最近是不更新了還是怎么回事,所以現(xiàn)在暫時(shí)還沒發(fā)布到阿里云的 AppHub。你如果想要現(xiàn)在體驗(yàn),可以直接拉取 Github 上的 chart 配置,自己打包安裝。
一個(gè) Pod 中可以有多個(gè) container,也可以有多個(gè) init container,init container 會(huì)在應(yīng)用啟動(dòng)之前啟動(dòng),并且如果有多個(gè)應(yīng)用會(huì)依次啟動(dòng),只有一個(gè)運(yùn)行成功了,才會(huì)啟動(dòng)下一個(gè),所有 init container 都運(yùn)行結(jié)束了,應(yīng)用才會(huì)啟動(dòng),因此,我們可以借助 init container 來檢查應(yīng)用的依賴(如:db/redis/es...)是否已經(jīng)可用。
Init Container 使用示例
apiVersion: v1 kind: Pod metadata:name: myapp-podlabels:app: myapp spec:containers:- name: reservation-serverimage: weihanli/activityreservation:devports:- name: httpcontainerPort: 80protocol: TCPlivenessProbe:httpGet:path: /healthport: httpinitialDelaySeconds: 60periodSeconds: 10readinessProbe:httpGet:path: /api/noticeport: httpinitialDelaySeconds: 60periodSeconds: 10initContainers:- name: init-redisimage: busybox:1.31command: ['sh', '-c', 'until nslookup redis-server; do echo waiting for redis; sleep 2; done;']- name: init-mysqlimage: busybox:1.31command: ['sh', '-c', 'until nslookup mysql-server; do echo waiting for mysql; sleep 2; done;']上面這一示例定義了兩個(gè) init container,一個(gè)用來檢查 redis 是否啟動(dòng)成功,另外一個(gè)用來檢查 mysql 是否啟動(dòng)成功,開始部署的時(shí)候,首先會(huì)通過 nslookup 檢查 redis 是否成功啟動(dòng),檢測(cè)到 redis 啟動(dòng)了之后,域名解析也就會(huì)成功,然后會(huì)檢查 mysql 的狀態(tài),mysql 也成功啟動(dòng)之后才會(huì)開始啟動(dòng) reservation-server container
查看 pod 信息:
kubectl describe po reservation-server-59fb5447f7-gb5jg從上面的信息可以看到結(jié)果是符合預(yù)期的,首先是創(chuàng)建并啟動(dòng) init-redis 的容器,然后創(chuàng)建并啟動(dòng) init-mysql 容器,最后創(chuàng)建并啟動(dòng) reservation-server 容器,從 pod 狀態(tài)來看,redis 和 mysql 還未 ready 時(shí),resrvation-server 容器也不會(huì)啟動(dòng)
查看 init-redis 的日志
kubectl logs reservation-server-59fb5447f7-gb5jg -c init-redis查看 init-mysql 的日志:
kubectl logs reservation-server-59fb5447f7-gb5jg -c init-mysqlMemo
通過 init container 的配置終于可以解決依賴的服務(wù)還沒有 ready 應(yīng)用就啟動(dòng)從而導(dǎo)致應(yīng)用多次重啟之后才能正常工作的問題~~
Reference
- https://kubernetes.io/docs/concepts/workloads/pods/init-containers
- https://github.com/WeihanLi/ActivityReservation/blob/dev/k8s/charts/reservation-server/templates/deployment.yaml
- https://github.com/WeihanLi/ActivityReservation/tree/dev/k8s/charts/reservation-server
總結(jié)
以上是生活随笔為你收集整理的k8s 查看mysql 日志_k8s 使用 Init Container 确保依赖的服务已经启动的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php mysql 分组 分页_简单的P
- 下一篇: linux cmake编译源码,linu