先了解下常用的三种部署方式的简单介绍以及它们的优缺点:
Vercel 部署:
优点:
- 极其简单:Vercel 提供了与 Next.js 集成良好的部署平台,使得部署变得非常容易。
- 自动化:Vercel 提供自动部署、CI/CD 和部署预览等功能,大大简化了部署流程。
- 高性能:Vercel 的服务器分布在全球多个地点,确保站点的高性能和快速加载速度。
缺点:
- 有费用:尽管有免费套餐,但高级功能可能需要付费。
- 有一定学习曲线:对于初学者来说,可能需要一些时间来适应 Vercel 平台。
服务器部署:
优点:
- 灵活性:你可以选择任何云提供商或自己的服务器来托管 Next.js 应用,从而具有更大的自定义和控制权。
- 适用于大型应用:适用于需要大规模处理的应用,可以根据需求调整服务器资源。
缺点:
- 更复杂:需要自行设置服务器环境、Nginx 或其他反向代理,以及部署流程,这可能相对复杂,特别是对新手来说。
- 成本:取决于所选的云提供商,成本可能会较高,尤其是在流量大或需要高性能服务器时。
静态部署:
GitHub Pages 部署:
优点:
- 免费:GitHub Pages 是免费托管静态文件的好选择。
- 集成:与 GitHub 仓库集成,使得发布变得非常简单。
- 适用于文档和演示:适用于文档站点、演示和小型项目。
缺点:
- 有限制:GitHub Pages 有一些限制,如每月带宽限制,不适合大规模应用。
- 静态:GitHub Pages 仅支持静态文件托管,对于需要服务器端渲染的应用不适用。
由于 GitHub Pages 是静态网站托管服务,因此它不支持在服务端渲染应用程序。
因此,您需要使用 Next.js 的静态导出功能来生成静态文件并将其部署到 GitHub Pages 上。
Vercel 部署
这个最简单了,直接在 GitHub 新建 Next.js 项目之后在 Vercel 导入即可,不仅支持自动部署,还可以提供免费的服务运行环境。
可以参考官方文档:vercel next depoly
当然,Vercel部署的网站是会自动分配一个可访问的 vercel.app
后缀的域名的,但是国内因为某些原因访问不了,这里告诉大家一个方法,可以在国内购买一个域名,然后绑定一下就可以了。
部署到 Node 服务器
Next.js可以部署到任何支持 Node.js 的托管提供商。例如,阿里云服务器或腾讯云服务器。
如果是我们自己购买的云服务,可以使用这种方式,首先先在服务里安装 Node 环境,然后执行 build
命令以后,生成的内容默认在.next
文件夹里
{
"scripts": {
"dev": "next dev",
"build": "next build",
"start": "next start"
}
}
然后,运行 npm run build
以生成应用程序。最后,运行 npm run start
以启动 Node.js 服务器。此服务器支持 Next.js 的所有功能。
也可以用 docker 部署。
Next.js 可以部署到任何支持Docker 的托管提供商容器。部署到Kubernetes等容器编排器时,您可以使用此方法或HashiCorp Nomad,或者在任何云提供商的单个节点内运行时。
- 安装 Docker在你的机器上
- 克隆with-docker例子
- 构建你的容器:
docker build -t nextjs-docker .
- 运行你的容器:
docker run -p 3000:3000 nextjs-docker
如果您需要在多个环境中使用不同的环境变量,请查看官方的with-docker-multi-env例子。
静态部署(Github Page)
当我们的应用没有服务相关的功能时,可以选择静态部署,静态部署和正常使用 React 部署是一样的,只不过我们是部署在 GitHub 上。
首先在next.config.js
中配置:
const nextConfig = {
output: "export",
};
将打包命令加入到package.json
里,然后执行npm run build
。
"scripts": {
"build": "next build && next export"
}
默认生成的静态页面在out
文件夹里
## Github 配置
设置 pages 页面的分支为 gh-pages 分支。
在next.config.js
中设置打包后静态资源的路径,也就是仓库名字。
/** @type {import('next').NextConfig} */
const repo = "dir-tree";
const assetPrefix = `/${repo}/`;
const basePath = `/${repo}`;
const nextConfig = {
basePath,
assetPrefix,
output: "export",
};
module.exports = nextConfig;
我们本地开发不需要带有repo的前缀,所以为了不影响本地开发,所以我们需要加个判断,只有在GitHub构建时才加前缀。
/** @type {import('next').NextConfig} */
const isGithubActions = process.env.GITHUB_ACTIONS || false;
let assetPrefix = "";
let basePath = "";
if (isGithubActions) {
// 去掉 `<owner>/`
const repo = process.env.GITHUB_REPOSITORY.replace(/.*?\//, "");
assetPrefix = `/${repo}/`;
basePath = `/${repo}`;
}
const nextConfig = {
basePath,
assetPrefix,
output: "export",
};
module.exports = nextConfig;
改完之后,直接推送到仓库,即可成功!
如果你想看完整代码可以去 我的仓库 查阅
常见问题
如果在构建过程中遇到这个问题,请按照第二图解决即可。
参考
- Github Pages Action
- 自动令牌身份验证
- (主要借鉴) 阮一峰 - GitHub Actions 入门教程
- (主要借鉴) Using GitHub Pages to Build, Deploy, and Host Next.js
- Using Composite GitHub Actions to make your Workflows smaller and more reusable
- GitHub Actions - Announcing the GitHub Actions extension for VS Code
- Deploying to Github Pages? Don't Forget to Fix Your Links
- Automating build/deploy CI/CD with GitHub Actions
- 如何使用 GitHub Actions 实现开源项目的自动化
- 使用 GitHub Actions 构建、部署 Next.js 并将其托管到 GitHub Pages
- Vercel static exports
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。