跳至主要内容

使用 Prisma Migrate 部署数据库更改

要将待处理的迁移应用到暂存、测试或生产环境,请在 CI/CD 管道中运行 migrate deploy 命令

npx prisma migrate deploy
信息

本指南**不适用于 MongoDB**。
对于 MongoDB,使用 db push 代替 migrate deploy

何时运行 prisma migrate deploy 确切取决于您的平台。例如,简化的 Heroku 工作流程包括

  1. 确保 ./prisma/migration 文件夹在源代码控制中
  2. 发布阶段 运行 prisma migrate deploy

理想情况下,migrate deploy 应该是自动化 CI/CD 管道的一部分,我们通常不建议在本地运行此命令以将更改部署到生产数据库(例如,通过临时更改 DATABASE_URL 环境变量)。在本地存储生产数据库 URL 通常不被认为是良好实践。

请注意,为了运行 prisma migrate deploy 命令,您需要访问通常添加到 devDependenciesprisma 依赖项。某些平台(如 Vercel)在构建期间会修剪开发依赖项,从而阻止您调用该命令。这可以通过将 prisma 设为生产依赖项,将其移动到 package.json 中的 dependencies 来解决。有关 migrate deploy 命令的更多信息,请参阅

使用 GitHub Actions 部署数据库更改

作为 CI/CD 的一部分,您可以在管道中运行 prisma migrate deploy 以将待处理的迁移应用到生产数据库。

这是一个将针对您的数据库运行迁移的示例操作

deploy.yml
name: Deploy
on:
push:
paths:
- prisma/migrations/**
branches:
- main

jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout repo
uses: actions/checkout@v3
- name: Setup Node
uses: actions/setup-node@v3
- name: Install dependencies
run: npm install
- name: Apply all pending migrations to the database
run: npx prisma migrate deploy
env:
DATABASE_URL: ${{ secrets.DATABASE_URL }}

突出显示的行表示此操作仅在 prisma/migrations 目录发生更改时运行,因此 npx prisma migrate deploy 仅在迁移更新时运行。

确保您已将 DATABASE_URL 变量在您的仓库中设置为秘密,连接字符串周围没有引号。

© . This site is unofficial and not affiliated with Prisma Data, Inc.