应用中心框架部署方案已经全新升级,您可以通过 SCF Web Function
,快速部署您的 Egg 业务上云。
注意:应用控制台部署与函数直接部署有什么区别?
通过应用部署或函数部署,均可以基于 Web 函数,快速部署常见 Web 框架。
本篇文档为您介绍应用控制台的部署方案,您也可以通过命令行完成部署,具体操作请参考 产品文档。
本地已安装 Node.js 运行环境。
mkdir egg-example && cd egg-example
npm init egg --type=simple
npm i
npm run dev
open http://localhost:7001
接下来执行以下步骤,对本地已创建完成的项目进行简单修改,使其可以通过 Web Function 快速部署,对于 Egg 框架,具体改造说明如下:
0.0.0.0:9000
。/tmp
目录可读写。scf_bootstrap
启动文件。1. (可选)配置 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
2. 控制台上传
登录 Serverless 控制台,选择Web 应用>Egg 框架,上传方式可以选择本地上传或代码仓库拉取。
您可以在控制台完成启动文件 scf_bootstrap
内容配置,配置完成后,控制台将为您自动生成 启动文件,和项目代码一起打包部署。
注意:启动文件以项目内文件为准,如果您的项目里已经包含
scf_bootstrap
文件,将不会覆盖该内容。
配置完成后,单击完成,部署您的 Egg 项目。
您可在“高级配置”里进行更多应用管理操作,如创建层、绑定自定义域名、配置环境变量等。
本页内容是否解决了您的问题?