打包
打包CLI命令
使用Serverless CLI工具,可以将项目打包,而无需将其部署到华为云。这最好与CI/CD工作流一起使用,以确保可部署产物一致。
serverless package
打包配置
有时,您可能希望对函数产物以及它们的打包方式有更多的控制。
您可以使用patterns配置来更多地控制打包过程。
- Patterns
您可以定义将从结果产物中排除/包括的全局模式。如果您希望排除文件,可以使用前缀为“!”的全局模式,如:!exclude-me/**。Serverless Framework将运行全局模式,以便您始终可以重新包含以前排除的文件和目录。
示例
排除所有node_modules,然后专门使用exclude重新包含的特定模块(在本例中为node-fetch):package: patterns: - '!node_modules/**' - 'node_modules/node-fetch/**'
排除handler.js以外的所有文件:package: patterns: - '!src/**' - src/function/handler.js
如果要排除目录,请不要忘记使用正确的全局语法,可参考如下:package: patterns: - '!tmp/**' - '!.git/**'
- 产物
如果配置了此功能,Serverless将不会压缩您的服务,因此将忽略patterns,可以选择使用产物或模式进行部署。
如果您的开发环境允许您像Maven为Java一样生成可部署的产物,则产物选项能起到很大帮助。
示例service: my-service package: patterns: - '!tmp/**' - '!.git/**' - some-file artifact: path/to/my-artifact.zip
- 分别打包函数
如果您希望对部署的函数进行更多的控制,您可以配置将它们分别进行打包。这样可以通过更多控制,对部署进行优化。要启用单独打包,请在服务或函数的打包设置中将individually设置为true。
然后,对于每个函数,您都可以使用适用于整个服务的patterns或artifact配置选项。patterns选项将与服务选项合并,在打包期间为每个函数创建一个patterns配置。service: my-service package: individually: true patterns: - '!excluded-by-default.json' functions: hello: handler: handler.hello package: # We're including this file so it will be in the final package of this function only patterns: - excluded-by-default.json world: handler: handler.hello package: patterns: - '!some-file.js'
您还可以选择需要单独打包的函数,并通过在函数级别设置individually标志,让其余的函数使用服务包:service: my-service functions: hello: handler: handler.hello world: handler: handler.hello package: individually: true
- 开发依赖
Serverless将根据您的服务正在使用的运行时来自动检测和排除开发依赖项。从而确保ZIP文件中仅包含与生产相关的软件包和模块。这样做可以大幅减小上传到云提供商的部署包总大小。
可以通过将excludeDevDependency包配置设置为false来选择退出自动排除开发依赖项:package: excludeDevDependencies: false