跳到主要内容

如何配置持续集成(CI)构建缓存

为了提升构建性能,Next.js 将缓存保存到 .next/cache,该缓存在构建之间共享。

要在持续集成(CI)环境中利用此缓存,你的 CI 工作流需要配置为在构建之间正确持久化缓存。

如果你的 CI 未配置为在构建之间持久化 .next/cache,你可能会看到未检测到缓存错误。

以下是一些常见 CI 提供商的缓存配置示例:

Vercel

Next.js 缓存会自动为你配置。你无需执行任何操作。如果你在 Vercel 上使用 Turborepo,请在此了解更多

CircleCI

编辑 .circleci/config.yml 中的 save_cache 步骤以包含 .next/cache

steps:
- save_cache:
key: dependency-cache-{{ checksum "yarn.lock" }}
paths:
- ./node_modules
- ./.next/cache

如果你没有 save_cache 键,请按照 CircleCI 的设置构建缓存文档进行操作。

Travis CI

.travis.yml 中添加或合并以下内容:

cache:
directories:
- $HOME/.cache/yarn
- node_modules
- .next/cache

GitLab CI

.gitlab-ci.yml 中添加或合并以下内容:

cache:
key: ${CI_COMMIT_REF_SLUG}
paths:
- node_modules/
- .next/cache/

Netlify CI

使用 Netlify 插件@netlify/plugin-nextjs

AWS CodeBuild

buildspec.yml 中添加(或合并)以下内容:

cache:
paths:
- 'node_modules/**/*' # 缓存 `node_modules` 以加快 `yarn` 或 `npm i`
- '.next/cache/**/*' # 缓存 Next.js 以加快应用程序重建

GitHub Actions

使用 GitHub 的 actions/cache,在工作流文件中添加以下步骤:

uses: actions/cache@v4
with:
# 有关使用 `yarn`、`bun` 或其他包管理器的缓存,请参见 https://github.com/actions/cache/blob/main/examples.md,或者你可以利用 actions/setup-node 进行缓存 https://github.com/actions/setup-node
path: |
~/.npm
${{ github.workspace }}/.next/cache
# 当包或源文件更改时生成新缓存。
key: ${{ runner.os }}-nextjs-${{ hashFiles('**/package-lock.json') }}-${{ hashFiles('**/*.js', '**/*.jsx', '**/*.ts', '**/*.tsx') }}
# 如果源文件更改但包没有更改,从先前的缓存重建。
restore-keys: |
${{ runner.os }}-nextjs-${{ hashFiles('**/package-lock.json') }}-

Bitbucket Pipelines

bitbucket-pipelines.yml 的顶层(与 pipelines 同级)添加或合并以下内容:

definitions:
caches:
nextcache: .next/cache

然后在管道的 stepcaches 部分中引用它:

- step:
name: your_step_name
caches:
- node
- nextcache

Heroku

使用 Heroku 的自定义缓存,在顶级 package.json 中添加 cacheDirectories 数组:

"cacheDirectories": [".next/cache"]

Azure Pipelines

使用 Azure Pipelines 的缓存任务,在管道 yaml 文件中添加以下任务,位置在执行 next build 的任务之前:

- task: Cache@2
displayName: 'Cache .next/cache'
inputs:
key: next | $(Agent.OS) | yarn.lock
path: '$(System.DefaultWorkingDirectory)/.next/cache'

Jenkins (Pipeline)

使用 Jenkins 的 Job Cacher 插件,在 Jenkinsfile 中添加以下构建步骤,位置在你通常运行 next buildnpm install 的地方:

stage("Restore npm packages") {
steps {
// 基于 GIT_COMMIT 哈希将锁定文件写入缓存
writeFile file: "next-lock.cache", text: "$GIT_COMMIT"

cache(caches: [
arbitraryFileCache(
path: "node_modules",
includes: "**/*",
cacheValidityDecidingFile: "package-lock.json"
)
]) {
sh "npm install"
}
}
}
stage("Build") {
steps {
// 基于 GIT_COMMIT 哈希将锁定文件写入缓存
writeFile file: "next-lock.cache", text: "$GIT_COMMIT"

cache(caches: [
arbitraryFileCache(
path: ".next/cache",
includes: "**/*",
cacheValidityDecidingFile: "next-lock.cache"
)
]) {
// 即 `next build`
sh "npm run build"
}
}
}