有奖捉虫:办公协同&微信生态&物联网文档专题 HOT
应用中心框架部署方案已经全新升级,您可以通过 SCF Web Function,快速部署您的 Next.js 业务上云。
注意:
应用控制台部署与函数直接部署有什么区别? 通过应用部署或函数部署,均可以基于 Web 函数,快速部署常见 Web 框架。
如果您只关注代码逻辑开发,无需额外资源创建,可以通过 Serverless 控制台,完成快速部署。
如果除了代码部署外,您还需要更多能力或资源创建,如自动创建层托管依赖、一键实现静态资源分离、支持代码仓库直接拉取等,可以通过应用控制台,完成 Web 应用的创建工作。

前提条件

在使用腾讯云 Serverless 应用中心之前,您需要 注册腾讯云账号 并完成 实名认证
注意:
本文档主要介绍控制台部署方案,您也可以通过命令行完成部署,请参考具体操作请参见 产品文档

操作步骤

模板部署:部署 Next.js 示例代码

2. 单击新建应用,选择Web 应用 > Next.js 框架,如下图所示:


3. 单击下一步,完成基础配置选择。


4. 上传方式,选择示例代码直接部署,单击完成,即可开始应用的部署。
5. 部署完成后,您可在应用详情页面,查看示例应用的基本信息,并通过 API 网关生成的访问路径 URL 进行访问,查看您部署的 Next.js 项目。



自定义部署:快速部署 Web 应用

前提条件

本地已安装 Node.js 运行环境。为了更好的兼容性,我们建议您参考以下说明选择合适的运行环境版本:
如您使用“文件夹上传”或“代码仓库”的方式上传代码,请选择 Nodejs 12.16.1版本。
如您使用 Serverless Cloud Framework 的方式部署函数,可选择 Nodejs 6.10.3、8.9.4、10.15.3、12.16.1、14.18.2、16.13.1、18.15.0中的任意版本。
下文以“文件夹上传”或“代码仓库”上传代码为例:

本地开发

1. 参考 Next.js 官方文档,安装并初始化您的 Next.js 项目:
npx create-next-app
2. 在根目录下,执行以下命令在本地直接启动服务。
cd my-app && npm run dev
3. 打开浏览器访问 http://localhost:3000,即可在本地完成 Next.js 示例项目的访问。



部署上云

接下来执行以下步骤,对已初始化的项目进行简单修改,使其可以通过 Web Function 快速部署,此处项目改造通常分为以下两步:
修改监听地址与端口为 0.0.0.0:9000
新增 scf_bootstrap 启动文件。
具体步骤如下:
1. 在项目根目录下新建 scf_bootstrap 启动文件,在该文件添加如下内容(用于启动服务并指定启动端口):
说明:
您也可以在控制台完成该模块配置。
#!/var/lang/node12/bin/node

const { nextStart } = require('next/dist/cli/next-start');
nextStart([ '--port', '9000', '--hostname', '0.0.0.0' ])
注意:
1. 此处仅为示例启动文件,具体请根据您的业务场景进行调整。
2. 示例使用的是云函数标准 node 环境路径,本地调试时,注意修改成您的本地路径。
新建完成后,还需执行以下命令修改文件可执行权限,默认需要 777755 权限才可正常启动。
MacOS 系统
Linux 系统
Windows 系统
执行以下命令:
chmod 777 scf_bootstrap
执行以下命令:
chmod 777 scf_bootstrap
执行以下命令:
icacls scf_bootstrap /grant:r "Everyone":F
2. 本地配置完成后,执行启动文件,确保您的服务可以本地正常启动,接下来,登录 Serverless 控制台,选择Web 应用 > Next.js 框架,上传方式可以选择本地上传代码仓库拉取
您可以在控制台完成启动文件 scf_bootstrap 内容配置,配置完成后,控制台将为您自动生成 启动文件,和项目代码一起打包部署。
注意:
启动文件以项目内文件为准,如果您的项目里已经包含 scf_bootstrap 文件,将不会覆盖该内容。
配置完成后,单击完成,部署您的 Next.js 项目。