当前位置:  开发笔记 > 后端 > 正文

暂存数据库困境

如何解决《暂存数据库困境》经验,为你挑选了2个好方法。

假设有3个数据库

生产

分期

开发

据我所知,Staging数据库需要与Production数据库同步但是,

当我们开发时,我们可以使用Dev数据库和更改模式做任何我们想做的事情.现在来了鸡和鸡蛋问题.

要在Staging中进行测试,需要根据Dev数据库中所做的更改来更改Staging数据库模式.但是Staging数据库需要与Production同步.

你们是如何解决这个问题的?



1> RichH..:

您需要将所有对dev数据库的更改写为以特定顺序运行的SQL迁移脚本.除非脚本位于脚本中,否则请勿更改数据库结构.除非脚本在脚本中,否则不要更新,插入或删除任何行.

理想情况下,有一种方法可以跟踪针对您找到的任何数据库版本运行的脚本.

然后您可以按如下方式更新阶段.

转储生产数据库

使用生产转储填充阶段数据库

在阶段运行迁移

检查迁移是否有效(单元测试,手动检查)

一切正常......

使用mysqldump命令转储prod数据库(因为它可能已更改)在服务器上保留备份

在prod上运行迁移

测试迁移对产品起作用

喝啤酒(边看错误日志)



2> BradC..:

分段需要与生产同步,只能达到部署新更改的程度.

那或称为第四个环境,称为Test,其中验证了新的升级.我们称之为UAT/Test,它通常是Staging服务器上的第二个数据库.

确切的方法取决于您如何保持同步.你真的在使用复制吗?或者只是Prod to Stage的备份/恢复?

推荐阅读
N个小灰流_701
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有