优化 Serverless Nestjs 冷起动时间
本文主要介绍的是如何减小部署包的体积,从而减少冷启动时间。
在方式上,其实各个Nodejs
框架优化冷启动的方式都差不多,这样的方案完全可以无缝同步到其他的框架中,我们只需要选择自己喜欢的打包工具即可。
Nestjs
默认支持使用 webpack
进行打包,只需在 nest-cli
的 build script
参数中配置 --webpack
即可:
nest build --webpack
默认使用根目录下的 webpack.config.js
所以为了减小部署包的体积,我们可以这么写:
const path = require('path');
module.exports = (options, webpack) => {
// 懒加载的包
const lazyImports = [
'@nestjs/microservices/microservices-module',
'@nestjs/websockets/socket-module',
'swagger-ui-express',
'class-transformer/storage',
];
/** @type {import('webpack').Configuration} */
const config = {
...options,
// 有些不能打包,必须安装的可以放在 externals 数组中
externals: [],
plugins: [
...options.plugins,
new webpack.IgnorePlugin({
checkResource(resource) {
if (lazyImports.includes(resource)) {
try {
require.resolve(resource);
} catch (err) {
return true;
}
}
return false;
},
}),
],
// serverless 入口文件
entry: './src/sls.ts',
output: {
filename: 'index.js',
path: path.resolve(__dirname, 'code'),
chunkFormat: 'commonjs',
library: {
type: 'commonjs2',
},
},
};
return config;
};
这样就大大减小了 npm
包的体积,从而加快了部署和冷启动的速度。
这个配置,和官方提供的有些不同,主要是因为官方的场景主要在国外的云厂商,而这个配置是针对阿里云,腾讯云进行配置的。
部署到阿里云
快速使用 serverless-devs
一键部署到阿里云函数计算。
详见模板:serverless-devs-nestjs
本网站是一个以CSS、JavaScript、Vue、HTML为核心的前端开发技术网站。我们致力于为广大前端开发者提供专业、全面、实用的前端开发知识和技术支持。 在本网站中,您可以学习到最新的前端开发技术,了解前端开发的最新趋势和最佳实践。我们提供丰富的教程和案例,让您可以快速掌握前端开发的核心技术和流程。 本网站还提供一系列实用的工具和插件,帮助您更加高效地进行前端开发工作。我们提供的工具和插件都经过精心设计和优化,可以帮助您节省时间和精力,提升开发效率。 除此之外,本网站还拥有一个活跃的社区,您可以在社区中与其他前端开发者交流技术、分享经验、解决问题。我们相信,社区的力量可以帮助您更好地成长和进步。 在本网站中,您可以找到您需要的一切前端开发资源,让您成为一名更加优秀的前端开发者。欢迎您加入我们的大家庭,一起探索前端开发的无限可能!