- 最新动态
- 功能总览
- 产品介绍
- 计费说明
- 快速入门
- 用户指南
-
最佳实践
- FunctionGraph最佳实践汇总
- 性能优化与安全类实践
-
数据处理类实践
- 使用FunctionGraph函数对OBS中的图片进行压缩
- 使用FunctionGraph函数为OBS中的图片打水印
- 使用FunctionGraph函数对DIS数据进行格式转换并存储到CloudTable
- 使用FunctionGraph函数实现通过API方式上传文件
- 使用FunctionGraph函数对IoTDA中的设备坐标数据进行转换
- 使用FunctionGraph函数对OBS中的文件进行加解密
- 使用FunctionGraph函数识别LTS中的异常业务日志并存储到OBS
- 使用FunctionGraph函数对LTS中的日志进行实时过滤
- 使用FunctionGraph函数流对OBS中的图片进行旋转
- 使用FunctionGraph函数流对图片进行压缩和打水印
- 功能应用类实践
- 函数构建类实践
- 开发指南
- API参考
- SDK参考
- 场景代码示例
-
常见问题
-
产品咨询
- 使用FunctionGraph是否需要开通计算、存储、网络等服务?
- 使用FunctionGraph开发程序之后是否需要部署?
- FunctionGraph为函数分配的磁盘空间有多少?
- 是否支持在函数中启动TCP的监听端口,通过EIP接收外部发送过来的TCP请求?
- 函数发起HTTP请求的源地址如何获取?
- FunctionGraph是否支持对上传的zip文件进行反编译?
- FunctionGraph的函数是否支持功能扩展?
- FunctionGraph中的代码是如何隔离的?
- 函数常规信息中的“应用”如何理解?
- 用户需要为函数的冷启动时间付费吗?
- 函数计费中的调用次数,是某一账号下在不同region的所有函数的调用次数总和吗?
- Python语言的函数从V1版本迁移到V2版本时需注意哪些兼容性问题?
- FunctionGraph函数支持哪些编程语言?
- 创建函数
-
配置函数
- 能否在函数环境变量中存储敏感信息?
- FunctionGraph的函数如何读写上传的文件?
- 为函数挂载文件系统时,报“failed to mount exist system path”
- FunctionGraph如何实现域名解析?
- FunctionGraph如何通过域名访问专享版APIG中注册的接口?
- FunctionGraph函数通过域名访问APIG中注册的接口时,报域名无法解析?
- 使用定制运行时语言的函数能操作哪些目录?
- FunctionGraph的函数支持哪些中文字体?
- 能否在函数代码中使用线程和进程?
- 函数如何访问MySQL数据库?
- 函数无法通过VPC连接对应的Redis?
- 如何读取函数的请求头?
- Python语言的函数中,中文注释报乱码错误
-
调用函数
- FunctionGraph的函数执行需要多长时间?
- FunctionGraph的函数执行包含了哪些过程?
- FunctionGraph函数长时间不执行时,相关的实例会如何处理?
- 如何获取函数运行过程中的内存使用量信息?
- 为什么首次调用函数时速度会比较慢?
- 为什么函数实际使用内存大于预估内存,甚至触发内存溢出OOM?
- 函数执行失败返回“runtime memory limit exceeded”时,如何查看内存占用大小?
- 自定义镜像函数执行失败报“CrashLoopBackOff”
- 同步调用函数时,未收到调用响应的可能原因?
- 函数中os.system("command &")命令的执行日志未采集,应如何处理?
- 函数执行超时的可能原因有哪些?
- 使用APIG触发器调用一个返回String的FunctionGraph函数时,报500错误
- Python2.7在执行reload(sys)后无法通过print打印日志
- 运行函数时报错error while loading shared libraries时如何处理?
- 配置触发器
- 配置依赖包
-
产品咨询
- 视频帮助
- 文档下载
- 通用参考
链接复制成功!
FunctionGraph性能优化实践
在Serverless技术日益普及的今天,性能优化已成为提升应用效率与用户体验的关键。
本篇旨在探讨FunctionGraph性能优化的最新实践,从冷启动优化、函数执行优化等方面,全面分析如何在不同场景下实现最优性能,为您提供实用的指导,帮助您在FunctionGraph上构建更高效、更稳定的应用。
代码优化
- 编写幂等代码。为函数编写幂等代码可确保函数以相同的方式处理重复事件。
- 合理使用连接池。保持连接复用,以减少新建连接的冷启动开销(如HTTP连接池、数据库连接池、Redis连接池等)。
- 避免每次调用时重新初始化变量对象(使用全局静态变量、单例等)。在函数调用中间件(如Redis、Kafka等)时,避免在handler方法中重复初始化client,应通过init方法或全局变量初始化client,以减少client的冷启动开销。
- 加强客户端异常重试机制。当调用函数返回非200状态码时(如500、429、504等),客户端依据具体业务需求,加入重试逻辑,能够进一步确保业务的可靠性。
- 使用恰当的日志记录。FunctionGraph函数中访问第三方服务、华为云服务和执行相关操作时,应记录日志,以便于后续的异常定位、性能优化及业务分析。
性能压测
对函数进行性能测试是确保选择最优配置的关键环节。在函数压测过程中,可利用平台提供的指标、日志、调用链等手段进一步分析函数性能数据,从而优化函数配置选择。具体可观测指标详情请参考函数监控概述。
精简代码和镜像瘦身
由于FunctionGraph在冷启动时会下载函数代码,下载代码的过程会影响启动时间。如果代码文件过大,下载时间将延长,导致FunctionGraph的启动时间增加。
如果使用自定义镜像函数,镜像越大,启动时间也会越长。因此,为了减少冷启动时间,应对应用程序进行优化,例如移除程序中不必要的代码、减少第三方库的依赖等。具体操作包括:在Node.js中执行“npm prune”命令,在Python中执行“autoflake”。
此外,某些第三方库中可能包括测试用例源代码、无用的二进制文件和数据文件等,清理这些文件可减少函数代码的下载和解压时间。
使用更大的内存
为函数配置较大内存可以提升CPU性能,从而加快函数启动和执行速度。您可以通过监测函数执行时间,评估不同内存配置对函数性能影响,进而选择最优内存大小。
使用公共依赖包加速
在编写函数代码时,通常会引入第三方依赖库,特别是使用Python语言构建函数时。在冷启动过程,系统会下载所需依赖包,如果依赖包体积过大,会延长启动时间。
FunctionGraph提供公共依赖包和私有依赖包两种依赖包。使用公共依赖包时,FunctionGraph会预先将其下载至执行节点中,以减少依赖包的下载时间。因此,建议优先使用FunctionGraph提供的公共依赖包,尽量减少私有依赖的使用。依赖包的相关介绍请参考函数依赖包。
配置预留实例
预留实例创建完成后,将自动加载该函数的代码、依赖包及执行初始化入口函数,并持续驻留环境。因此,为函数配置预留实例能够避免冷启动导致的时延问题。函数预留实例的配置操作请参考为函数配置预留实例。
使用函数初始化入口
对于需要频繁调用的函数,将初始化逻辑置于初始化入口可显著减少每次执行时间,例如初始化HTTP连接、初始化数据库连接等。函数初始化入口的配置操作请参考配置函数初始化。