如何在 k8s 部署 pod 时,让迁移只执行一次

动机

将执行迁移写到了镜像执行的脚本里,使用 k8s 部署一个三个副本的含有 laravel 容器的 pod

目前的问题

第一次部署的时候,由于数据库没有创建,pod 很快报错被重启了,之后创建了数据库,等待 pod 重启后执行一系列的脚本并启动容器进程。之后发现仍然报错重启,使用 kubectl logs 查看容器日志的时候发现在执行迁移的时候报错(SQL错误),说某表已经存在,我分析能导致这个问题的应该就是执行迁移过程中多个 pod 并发导致的,并且某个迁移文件执行出错了,导致没有将执行过的迁移数据写入到 migrations 表。请问如何解决这个问题?

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
最佳答案

单独设置一个 job for database migrate,或者将 deployment 的 rollingUpdate 滚动升级的 maxSurge 的值改为 1.

3年前 评论
讨论数量: 4

单独设置一个 job for database migrate,或者将 deployment 的 rollingUpdate 滚动升级的 maxSurge 的值改为 1.

3年前 评论
leo

是的,应该用 k8s 的 job

3年前 评论
sanders

我是这样思考的,大家看看对不对,这类需要只执行一次的脚本,又跟当前容器的本地资源无关,是否应该单独启动一个容器,执行后就回收。

3年前 评论
李铭昕

不得不说 K8s 功能确实强大。。这种 job 脚本,Swarm 里还得配合 宿主机 Crontab 才能用

3年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!