跳转到主要内容

从本地环境部署迁移

在两种情况下,您可能会考虑直接从本地环境向生产环境部署迁移。

  • 您有一个本地 CI/CD 管道
  • 您正在基线化生产环境

此页面概述了一些您可以执行此操作的示例,以及 为什么我们通常不建议这样做

本地 CI/CD 管道

如果您没有自动化的 CI/CD 流程,您可以在技术上通过以下方式从本地环境向生产环境部署新的迁移

  1. 确保您的迁移历史是最新的。您可以通过运行 prisma migrate dev 来做到这一点,这将从最新的更改生成迁移历史。
  2. 将您的本地连接 URL 替换为您的生产连接 URL
.env
//delete-next-line
DATABASE_URL="postgresql://johndoe:randompassword@localhost:5432/my_local_database"

//add-next-line
DATABASE_URL="postgresql://johndoe:randompassword@localhost:5432/my_production_database"
  1. 运行 prisma migrate deploy

由于以下原因,我们强烈不建议使用此解决方案

  • 您有将生产数据库连接 URL 暴露于版本控制的风险。
  • 您可能会意外地使用您的生产连接 URL,进而 覆盖或删除您的生产数据库

我们建议设置一个自动化的 CI/CD 管道

该管道应处理到暂存和生产环境的部署,并在管道步骤中使用 migrate deploy。有关示例,请参阅部署指南

基线化生产数据库

当您将 Prisma Migrate 添加到 现有数据库 时,您必须 基线化 生产数据库。基线化操作执行 一次,并且可以从本地实例完成。

Baselining production from local with Prisma ORM