热搜:前端 nest neovim nvim

优化 Serverless Nestjs 冷起动时间

lxf2023-06-18 03:30:12

优化 Serverless Nestjs 冷起动时间

本文主要介绍的是如何减小部署包的体积,从而减少冷启动时间。

在方式上,其实各个Nodejs框架优化冷启动的方式都差不多,这样的方案完全可以无缝同步到其他的框架中,我们只需要选择自己喜欢的打包工具即可。

Nestjs 默认支持使用 webpack 进行打包,只需在 nest-clibuild 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为核心的前端开发技术网站。我们致力于为广大前端开发者提供专业、全面、实用的前端开发知识和技术支持。 在本网站中,您可以学习到最新的前端开发技术,了解前端开发的最新趋势和最佳实践。我们提供丰富的教程和案例,让您可以快速掌握前端开发的核心技术和流程。 本网站还提供一系列实用的工具和插件,帮助您更加高效地进行前端开发工作。我们提供的工具和插件都经过精心设计和优化,可以帮助您节省时间和精力,提升开发效率。 除此之外,本网站还拥有一个活跃的社区,您可以在社区中与其他前端开发者交流技术、分享经验、解决问题。我们相信,社区的力量可以帮助您更好地成长和进步。 在本网站中,您可以找到您需要的一切前端开发资源,让您成为一名更加优秀的前端开发者。欢迎您加入我们的大家庭,一起探索前端开发的无限可能!