函数工作流 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时如何处理?
- 配置触发器
- 配置依赖包
-
产品咨询
- 视频帮助
- 文档下载
- 通用参考
链接复制成功!
FunctionGraph与基础设施即代码(IaC)
将FunctionGraph与基础设施即代码(IaC)结合使用
FunctionGraph函数不常单独运行。它与存储、网关、数据库和消息队列等其他资源结合,组成无服务应用程序。借助基础设施即代码(IaC),可以自动化部署流程,从而快速且重复地部署与更新函数及触发器配置。该方法加快了开发周期,简化了配置管理,确保每次都一致地部署资源。
适用于FunctionGraph的IaC工具
资源编排服务(Resource Formation Service,简称RFS)是完全支持业界事实标准Terraform(HCL + Provider)的新一代云服务资源终态编排引擎。基于业界开放生态HCL语法模板,实现云服务资源的自动化批量构建,帮助用户高效、安全、一致创建、管理和升级云服务资源(例如FunctionGraph,APIG实例,数据库实例等),能有效提升资源管理效率,并降低资源管理变更带来的安全风险。
RFS for FunctionGraph入门
- 编写Python脚本代码index.py文件,内容如下:
# -*- coding:utf-8 -*- import json def handler (event, context): return { "statusCode": 200, "isBase64Encoded": False, "body": json.dumps(event), "headers": { "Content-Type": "application/json" } }
- 将index.py代码文件打包为index.zip文件,把zip文件上传至OBS桶,获取OBS桶中的代码文件对象链接。
- 编写参数模板文件variables.tf,用于定义RFS模板用到的参数,内容如下:
variable "enterprise_project_id" { type = string description = " Specifies enterprise_project_id" default = "0" } variable "agency_name" { type = string description = " Specifies the agency to which the function belongs." default = "" } variable "region" { type = string description = " Specifies the region." default = "cn-north-7" } variable "code_url" { type = string description = "code_url" } variable "apig_id" { type = string description = "apig_id" default = "" }
- 编写RFS模板文件main.tf,用于定义函数及触发器,内容如下:
variable "enterprise_project_id" { type = string description = " Specifies enterprise_project_id" default = "0" } variable "agency_name" { type = string description = " Specifies the agency to which the function belongs." default = "" } variable "region" { type = string description = " Specifies the region." default = "cn-north-7" } variable "code_url" { type = string description = "code_url" } variable "apig_id" { type = string description = "apig_id" default = "" }
- 将上述main.tf和cariables.tf文件打包为一个components.zip文件。
- 登录资源编排服务RFS控制台,如图1所示选择“资源栈 > 立即创建资源栈”。可参考创建资源栈同步操作。
- 如图2所示填写参数,并上传components.zip文件。完成后单击“下一步”。
- 进入“参数配置”页面,填写配置参数。完成后单击“下一步”。
- 进入“资源栈设置”页面,配置IAM权限委托。其他参数保持默认即可,单击“下一步”确认部署资源栈。将自动在函数工作流控制台创建相关的函数与资源。
- 登录函数工作流控制台,在函数列表中单击函数名称进入函数详情页,单击“设置 > 触发器”,找到APIG触发器并复制调用URL,将其粘贴到浏览器中或运行以下curl命令。
curl -s <Trigger_Invoke_URL> # <Trigger_Invoke_URL>处填写APIG触发器的调用URL
响应是原始事件对象中选定属性的 JSON 表示,其中包含向 API Gateway 端点发出请求的相关信息。示例:
HTTP/1.1 200 OK Content-Length: 658 Connection: keep-alive Content-Type: application/json Date: Wed, 12 Mar 2025 08:59:18 GMT Server: api-gateway Strict-Transport-Security: max-age=31536000; includeSubdomains; X-Apig-Latency: 52 X-Apig-Ratelimit-Api: remain:97,limit:100,time:1 minute X-Apig-Ratelimit-Api: remain:29973,limit:30000,time:1 second X-Apig-Ratelimit-Api-Allenv: remain:199,limit:200,time:1 second X-Apig-Ratelimit-Api-Allenv: remain:29973,limit:30000,time:1 second X-Apig-Ratelimit-User: remain:3995,limit:4000,time:1 second X-Apig-Upstream-Latency: 14 X-Cff-Billing-Duration: 1 X-Cff-Invoke-Summary: {"funcDigest":"e6e9c99b8f5b9d6f9408d5210263330","duration":0.756,"billingDuration":1,"memorySize":128,"memoryUsed":33.207,"podName":"pool22-300-128-fusion-844bdc7755-bh55w","gpuMemorySize":0,"ephemeralStorage":512} X-Cff-Request-Id: b43781ee-49f3-4762-8c24-236c718d3391 X-Content-Type-Options: nosniff X-Download-Options: noopen X-Frame-Options: SAMEORIGIN X-Func-Err-Code: 0 X-Is-Func-Err: false X-Request-Id: 90a48d7a4c699780579f4edc8983cdaf X-Xss-Protection: 1; mode=block; {"requestContext": {"requestId": "90a48d7a4c699780579f4edc8983cdaf", "apiId": "01127600bb9f4d2ca8e532d1c378d8c8", "stage": ":DEBUG"}, "queryStringParameters": {}, "path": "/nxy-sasa", "httpMethod": "GET", "isBase64Encoded": true, "headers": {"host": "47f32d1efa1742f5a7ee5b720ca9c4a5.apig.cn-east-3.huaweicloudapis.com", "content-type": "application/json", "x-forwarded-host": "47f32d1efa1742f5a7ee5b720ca9c4a5.apig.cn-east-3.huaweicloudapis.com", "user-agent": "APIGatewayDebugClient/1.0", "x-forwarded-port": "443", "x-forwarded-proto": "https", "x-request-id": "90a48d7a4c699780579f4edc8983cdaf", "x-apig-mode": "debug"}, "body": "", "pathParameters": {}}
父主题: 开发工具