本文将为您指导如何通过 Web Function,将您的本地 Egg 项目快速部署到云端。
说明:本文档主要介绍控制台部署方案,您也可以通过命令行完成部署,详情请参见 通过命令行完成框架部署。
在使用腾讯云云函数服务之前,您需要 注册腾讯云账号 并完成 实名认证。
Egg
筛选函数模板,选择Egg 框架模板并单击下一步。如下图所示:本地已安装 Node.js 运行环境。
参考 Egg.js 官方文档,快速初始化示例项目。示例如下:
mkdir egg-example && cd egg-example
npm init egg --type=simple
npm i
在根目录下,执行以下命令在本地直接启动服务。
npm run dev
open http://localhost:7001
打开浏览器访问 http://localhost:7001
,即可在本地完成 Egg 示例项目的访问。
接下来执行以下步骤,对已初始化的项目进行简单修改,使其可以通过 Web Function 快速部署,此处项目改造通常分为以下三步:
0.0.0.0:9000
。/tmp
目录可读写。scf_bootstrap
启动文件。具体步骤如下:
scf_bootstrap
启动文件,在该文件添加如下内容(用于配置环境变量和启动服务,此处仅为示例,具体操作请以您实际业务场景进行调整):#!/var/lang/node12/bin/node
'use strict';
/**
* docker 中 node 路径:/var/lang/node12/bin/node
* 由于 serverless 函数只有 /tmp 读写权限,所以在启动时需要修改两个环境变量
* NODE_LOG_DIR 是为了改写 egg-scripts 默认 node 写入路径(~/logs)-> /tmp
* EGG_APP_CONFIG 是为了修改 egg 应有的默认当前目录 -> /tmp
*/
process.env.EGG_SERVER_ENV = 'prod';
process.env.NODE_ENV = 'production';
process.env.NODE_LOG_DIR = '/tmp';
process.env.EGG_APP_CONFIG = '{"rundir":"/tmp","logger":{"dir":"/tmp"}}';
const { Application } = require('egg');
// 如果通过层部署 node_modules 就需要修改 eggPath
Object.defineProperty(Application.prototype, Symbol.for('egg#eggPath'), {
value: '/opt',
});
const app = new Application({
mode: 'single',
env: 'prod',
});
app.listen(9000, '0.0.0.0', () => {
console.log('Server start on http://0.0.0.0:9000');
});
777
或 755
权限才可正常启动。示例如下:chmod 777 scf_bootstrap
部署完成后,即可在 SCF 控制台快速访问并测试您的 Web 服务,并且体验云函数多项特色功能,例如层绑定、日志管理等,享受 Serverless 架构带来的低成本、弹性扩缩容等优势。
本页内容是否解决了您的问题?