函数工作流 FunctionGraph
函数工作流 FunctionGraph
- 最新动态
- 功能总览
- 产品介绍
- 计费说明
- 快速入门
- 用户指南
-
最佳实践
- 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时如何处理?
- 配置触发器
- 配置依赖包
-
产品咨询
- 视频帮助
- 文档下载
- 通用参考
链接复制成功!
配置和查看函数的调用链信息
概述
用户在函数的“监控”页签,开启调用链能力。开启后可以在函数”监控 > 调用链“页面或跳转至APM服务”应用监控 > 调用链"页面,查看函数调用链信息。当前仅支持Java8和Java11函数。
约束与限制
当前特性仅“中东-利雅得”、“华北-北京四”、“华东-上海一”、“华南-广州”、“亚太-雅加达”、“土耳其-伊斯坦布尔”区域支持。
前提条件
- 调用链只支持512MB内存以上的函数,若函数内存低于512MB,无法使用调用链功能,请在“设置 > 常规信息”中,扩大函数“内存”后再使用调用链功能。
- 已开通应用性能管理APM服务的使用权限,具体请参见APM权限管理。若未开通,则无法获取调用链相关数据。
开通调用链
- 登录函数工作流控制台,在左侧的导航栏选择“函数 > 函数列表”。
- 单击函数名称,进入函数详情界面。
- 选择“监控 > 调用链”。
- 单击“点击开通”。
图1 开通调用链监控
- 此时调用链会从应用性能管理APM服务自动获取一个访问密钥AK/SK,如图2。
- 已有访问密钥:在“访问密钥ID”的下拉列表中选择“访问密钥ID”,选择完成后单击“确定”,完成开通。
- 无访问密钥:单击“创建”进入APM控制台,参见新增访问密钥,新增后的AK/SK会同步至函数工作流控制台。
- 管理调用链。
- 单击右上方“关闭调用链”,可以直接关闭调用链,关闭调用链后将不能查看函数调用链。
- 若在APM控制台对AK/SK进行了编辑修改,返回函数工作流控制台,单击右上方“更新AKSK”,在弹框中更新AK/SK。
查询调用链详情
- 返回函数工作流控制台,在左侧导航栏选择“函数 > 函数列表”,单击已开启调用链的函数,进入函数详情页面。
- 在“监控”页签下,选择“调用链”。
- 在左侧设置查询条件,完成后单击“查询Trace”。
图3 设置查询条件
- 时间:设置查询时间,注意起止查询时间间隔不能超过24小时。
- 响应时间:设置响应时间。
- 执行结果:选择“全部/执行成功/执行失败”。
- Trace ID:调用链的TraceID,填写该搜索条件后,其他搜索条件全部失效,只根据该TraceID搜索。
- 在右侧查看调用链详情。
查看单条调用链详情:在查询到的调用链结果中,单击调用链名称,进入APM控制台查看。
图4 单击调用链名称图5 单条详情查看所有调用链信息:单击“前往查看”,到APM进行完整的路径分析等更多操作。
图6 前往APM示例
- 如下是在函数A(DemoTestA)中通过HTTP请求方式调用函数B(DemoTestB)的完整函数执行过程。
图7 函数A调用函数B详情
①函数A方法的总耗时。
②通过HTTP请求调用函数B。
③进入函数B。
④执行executeQuery。
⑤执行Select查询语句。
- 如下是在函数首次调用包含冷启动的的完整函数执行过程。
图8 示例
Spans动作说明如下:
- load:是下载解压用户函数代码文件和依赖包的时间。
- preload:运行时加载用户函数代码和初始化函数执行环境的时间。
- init:初始化函数的执行时间,初始化函数只有在冷启动时才会被执行。
- processInvoke:函数的执行时间。
- 如下是在函数A(DemoTestA)中通过HTTP请求方式调用函数B(DemoTestB)的完整函数执行过程。
父主题: 查看监控指标与配置告警