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

动机

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

目前的问题

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

sanders
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案

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

4个月前 评论
讨论数量: 4
sanders

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

4个月前 评论
leo

是的,应该用 k8s 的 job

4个月前 评论

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

4个月前 评论
李铭昕

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

4个月前 评论

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