我应该在.gitignore文件中添加Django迁移文件吗?

由于迁移冲突,我最近遇到了很多git问题,我想知道是否应该将迁移文件标记为忽略。

如果是这样,我将如何去添加所有的迁移,我在我的应用程序,并将它们添加到.gitignore文件?


当前回答

Gitignore迁移,如果你有独立的db用于开发,分期和生产环境。出于开发目的,您可以使用本地sqlite DB并在本地进行迁移。 我建议你创建四个额外的分支:

Master - Clean fresh code without migrations. Nobody is connected to this branch. Used for code reviews only Development - daily development. Push/pull accepted. Each developer is working on sqlite DB Cloud_DEV_env - remote cloud/server DEV environment. Pull only. Keep migrations locally on machine, which is used for the code deployment and remote migrations of Dev database Cloud_STAG_env - remote cloud/server STAG environment. Pull only. Keep migrations locally on machine, which is used for the code deployment and remote migrations of Stag database Cloud_PROD_env - remote cloud/server DEV environment. Pull only. Keep migrations locally on machine, which is used for the code deployment and remote migrations of Prod database

注: 2、3、4——迁移可以保存在回购中,但是应该有严格的pull请求合并规则,所以我们决定找一个人来负责部署,所以唯一一个拥有所有迁移文件的人——我们的部署人员。每当我们在模型中有任何变化时,他都会保持远程DB迁移。

其他回答

您应该将迁移视为数据库模式的版本控制系统。Makemigrations负责将模型更改打包到单独的迁移文件中(类似于提交),migrate负责将这些文件应用到数据库中。

每个应用程序的迁移文件都存在于该应用程序内部的“migrations”目录中,并被设计为提交并作为其代码库的一部分分发。您应该在您的开发机器上进行一次迁移,然后在您同事的机器、登台机器以及最终的生产机器上运行相同的迁移。

黄金法则:在开发中只做一次,然后移植到所有开发中

您可以遵循以下流程。

您可以在本地运行makemigrations,这将创建迁移文件。将这个新的迁移文件提交到repo。

在我看来,你根本不应该在生产中进行大规模移民。您可以在生产环境中运行migrate,您将看到从本地提交的迁移文件应用了迁移。这样可以避免所有的冲突。

在LOCAL ENV中,要创建迁移文件,

python manage.py makemigrations 
python manage.py migrate

现在提交这些新创建的文件,如下所示。

git add app/migrations/...
git commit -m 'add migration files' app/migrations/...

在PRODUCTION ENV中,只执行以下命令。

python manage.py migrate

通常使用的解决方案是,在将任何内容合并到master之前,开发人员必须提取任何远程更改。如果在迁移版本中存在冲突,他应该将本地迁移(远程迁移已经由其他开发人员运行,并且可能已经在生产中运行)重命名为N+1。

在开发过程中,不提交迁移是可以的(但是不要添加忽略,不要添加它们)。但是一旦进入生产环境,您将需要它们来保持模式与模型更改同步。

然后需要编辑该文件,并将依赖项更改为最新的远程版本。

这适用于Django迁移,以及其他类似的应用程序(sqlalchemy+alembic, RoR等)。

DR:提交迁移,解决迁移冲突,调整git工作流程。

感觉你需要调整你的git工作流程,而不是忽略冲突。

理想情况下,每个新特性都在不同的分支中开发,并与拉请求合并。

如果有冲突,pr就不能合并,因此需要合并他的特性的人需要解决冲突,包括迁移。这可能需要不同团队之间的协调。

提交迁移文件是很重要的!如果出现冲突,Django甚至可以帮你解决这些冲突;)

提交迁移只会导致灾难。因为迁移在某种程度上是一条可以追溯的链,如果你有来自以前迁移的依赖,例如pip模块,你在项目生命周期的某个时刻使用过,然后停止使用。您可能会在迁移线程中发现这样的依赖关系,并且必须手动从迁移文件中删除这些导入。

结论,除非你是Django的神级开发者,否则最好避免在提交时添加迁移。