- 最新动态
- 功能总览
- 产品介绍
- 计费说明
- 快速入门
-
用户指南
- FunctionGraph业务使用流程
- 创建用户并授权使用FunctionGraph
- 创建函数
-
配置函数
- 函数配置概述
- 配置函数代码
- 配置函数的依赖包
- 配置函数的委托权限
- 配置函数的网络环境
-
配置函数的触发器
- 函数触发器概述
- 使用定时触发器(TIMER)
- 使用API网关服务(APIG专享版)触发器
- 使用API Connect(APIC)触发器
- 使用云审计服务(CTS)触发器
- 使用文档数据库服务(DDS)触发器(即将下线不建议使用)
- 使用数据接入服务(DIS)触发器
- 使用分布式消息服务 Kafka版(KAFKA)触发器
- 使用开源Kafka(OPENSOURCEKAFKA)触发器
- 使用分布式消息服务 RabbitMQ版(RABBITMQ)触发器
- 使用云数据库GeminiDB MongoDB触发器
- 使用云数据库GeminiDB DynamoDB触发器
- 使用设备接入(IoTDA)触发器
- 使用云日志服务(LTS)触发器
- 使用消息通知服务(SMN)触发器
- 使用对象存储服务(OBS)触发器
- 使用EventGrid触发器(OBS应用事件源)
- 使用EventGrid触发器(RocketMQ自定义事件源)
- 使用EventGrid触发器(RabbitMQ自定义事件源)
- 管理函数的触发器
- 在线调试函数
- 调用函数
- 管理函数
- 配置函数流
- 通过应用中心部署函数应用
- 通过KooCLI管理函数
- 申请扩大FunctionGraph配额
- 查看监控指标与配置告警
- 查看审计日志
-
最佳实践
- FunctionGraph最佳实践汇总
- 性能优化与安全类实践
-
数据处理类实践
- 使用FunctionGraph函数对OBS中的图片进行压缩
- 使用FunctionGraph函数为OBS中的图片打水印
- 使用FunctionGraph函数对DIS数据进行格式转换并存储到CloudTable
- 使用FunctionGraph函数实现通过API方式上传文件
- 使用FunctionGraph函数对IoTDA中的设备坐标数据进行转换
- 使用FunctionGraph函数对OBS中的文件进行加解密
- 使用FunctionGraph函数识别LTS中的异常业务日志并存储到OBS
- 使用FunctionGraph函数对LTS中的日志进行实时过滤
- 使用FunctionGraph函数流对OBS中的图片进行旋转
- 使用FunctionGraph函数流对图片进行压缩和打水印
-
功能应用类实践
- 使用FunctionGraph函数和CTS识别非法IP的登录登出操作
- 使用FunctionGraph函数定时开关华为云ECS
- 使用FunctionGraph函数作为后端实现APIG的自定义认证能力
- 使用FunctionGraph的Java函数配置Log4j2实现日志打印
- 使用FunctionGraph部署AI绘画Stable Diffusion应用
- 使用FunctionGraph部署AI绘画ComfyUI/ComfyUI+FLUX应用
- 使用FunctionGraph部署AI对话ChatGLM3应用
- 使用FunctionGraph部署DeepSeek-R1蒸馏模型
- 使用FunctionGraph快速部署MCP Server
- 函数构建类实践
- 开发指南
- 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函数长时间不执行时,相关的实例会如何处理?
- 如何获取函数运行过程中的内存使用量信息?
- 为什么首次调用函数时速度会比较慢?
- 函数执行失败返回“runtime memory limit exceeded”时,如何查看内存占用大小?
- 自定义镜像函数执行失败报“CrashLoopBackOff”
- 同步调用函数时,未收到调用响应的可能原因?
- 函数中os.system("command &")命令的执行日志未采集,应如何处理?
- 函数执行超时的可能原因有哪些?
- 使用APIG触发器调用一个返回String的FunctionGraph函数时,报500错误
- Python2.7在执行reload(sys)后无法通过print打印日志
- 运行函数时报错error while loading shared libraries时如何处理?
- 配置触发器
- 配置依赖包
-
产品咨询
- 视频帮助
- 文档下载
- 通用参考
链接复制成功!
Java函数开发指南(使用IDEA工具创建maven工程)
本章节介绍使用IDEA工具创建maven工程开发Java函数。关于Java函数接口定义、Initializer入口介绍以及SDK接口说明请参考Java函数开发概述。
步骤一:使用IDEA创建maven工程
- 创建函数工程
- 添加工程依赖
根据Java SDK下载提供的SDK地址,下载JavaRuntime SDK到本地开发环境解压,如图2所示。
- 将zip中的Runtime-2.0.5.jar拷贝到本地目录,例如d:\\runtime中,在命令行窗口执行如下命令安装到本地的maven仓库中。
mvn install:install-file -Dfile=d:\runtime\RunTime-2.0.5.jar -DgroupId=RunTime -DartifactId=RunTime -Dversion=2.0.5 -Dpackaging=jar
- 在pom.xml中配置dependency,如下所示。
<dependency> <groupId>Runtime</groupId> <artifactId>Runtime</artifactId> <version>2.0.5</version> </dependency>
- 配置其他的依赖包,以obs依赖包为例,如下所示。
<dependency> <groupId>com.huaweicloud</groupId> <artifactId>esdk-obs-java</artifactId> <version>3.21.4</version> </dependency>
- 在pom.xml中添加插件用来将代码和依赖包打包到一起。请把mainClass替换为真实的类。
<build> <plugins> <plugin> <artifactId>maven-assembly-plugin</artifactId> <configuration> <descriptorRefs> <descriptorRef>jar-with-dependencies</descriptorRef> </descriptorRefs> <archive> <manifest> <mainClass>com.huawei.demo.TriggerTests</mainClass> </manifest> </archive> <finalName>${project.name}</finalName> </configuration> <executions> <execution> <id>make-assembly</id> <phase>package</phase> <goals><goal>single</goal> </goals> </execution> </executions> </plugin> </plugins> </build>
- 将zip中的Runtime-2.0.5.jar拷贝到本地目录,例如d:\\runtime中,在命令行窗口执行如下命令安装到本地的maven仓库中。
- 配置函数资源
- 配置函数代码
在TriggerTests.java中定义函数运行入口,示例代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
package com.huawei.demo; import java.io.UnsupportedEncodingException; import java.util.HashMap; import java.util.Map; import com.huawei.services.runtime.Context; import com.huawei.services.runtime.entity.apig.APIGTriggerEvent; import com.huawei.services.runtime.entity.apig.APIGTriggerResponse; import com.huawei.services.runtime.entity.dis.DISTriggerEvent; import com.huawei.services.runtime.entity.dms.DMSTriggerEvent; import com.huawei.services.runtime.entity.lts.LTSTriggerEvent; import com.huawei.services.runtime.entity.smn.SMNTriggerEvent; import com.huawei.services.runtime.entity.timer.TimerTriggerEvent; public class TriggerTests { public APIGTriggerResponse apigTest(APIGTriggerEvent event, Context context){ System.out.println(event); Map<String, String> headers = new HashMap<String, String>(); headers.put("Content-Type", "application/json"); return new APIGTriggerResponse(200, headers, event.toString()); } public String smnTest(SMNTriggerEvent event, Context context){ System.out.println(event); return "ok"; } public String dmsTest(DMSTriggerEvent event, Context context){ System.out.println(event); return "ok"; } public String timerTest(TimerTriggerEvent event, Context context){ System.out.println(event); return "ok"; } public String disTest(DISTriggerEvent event, Context context) throws UnsupportedEncodingException{ System.out.println(event); System.out.println(event.getMessage().getRecords()[0].getRawData()); return "ok"; } public String ltsTest(LTSTriggerEvent event, Context context) throws UnsupportedEncodingException { System.out.println(event); event.getLts().getData(); System.out.println("raw data: " + event.getLts().getRawData()); return "ok"; } }
示例代码中添加了多个入口函数,分别使用了不同的触发器事件类型,可通过FunctionGraph控制台修改函数执行入口测试不同的入口函数。当函数的事件源是APIG时,相关约束条件请参考Base64解码和返回结构体的说明。
说明:
修改函数执行入口:
在FunctionGraph控制台左侧导航栏选择“函数 > 函数列表”,单击需要设置的“函数名称”进入函数详情页,选择“设置 > 常规设置”,配置“函数执行入口”参数,如图4所示。 - 工程编译打包
在命令行窗口执行如下命令进行编译打包。编译完成后在target目录会生成一个demo-jar-with-dependencies.jar。
mvn package assembly:single
步骤二:创建Java函数并测试
- 登录函数工作流控制台,左侧导航栏选择“函数 > 函数列表”,单击右上角“创建函数”进入创建函数页面,选择“创建空白函数”。
- 如图5所示,配置函数基本信息,配置完成后单击右下角“创建函数”完成创建。
- 进入函数详情页,在“代码”页签下,单击右侧“上传代码 > JAR文件 ”,如图6所示,添加步骤一:使用IDEA创建maven工程的JAR文件上传。
- 上传成功后,选择“设置 > 常规设置”,修改需要测试的函数执行入口参数,单击“保存”。
- 回到“代码”页签,单击代码编辑区的“测试”,选择“创建新的测试事件”,在云事件模板列表中选择需要测试的事件模板,单击“创建”。
- 单击“测试”,查看函数执行结果。
函数执行结果分为三部分,分别为函数返回(由callback返回)、执行摘要、日志输出(由console.log或getLogger()方法获取的日志方法输出),参考表1查看结果说明。
表1 执行结果说明参数项
执行成功
执行失败
函数返回
返回函数中定义的返回信息。
返回包含错误信息和堆栈异常报错信息的JSON文件。格式如下:
{ "errorMessage": "", "stackTrace": [] }
errorMessage:Runtime返回的错误信息
stackTrace:Runtime返回的堆栈异常报错信息
执行摘要
显示请求ID、配置内存、执行时长、实际使用内存和收费时长。
显示请求ID、配置内存、执行时长、实际使用内存和收费时长。
日志
打印函数日志,最多显示4KB的日志。
打印报错信息,最多显示4KB的日志。
说明:
如需测试示例代码中的其他事件源触发器,例如SMN事件源,可在函数的常规设置中,将函数执行入口修改为com.huawei.demo.TriggerTests.smnTest,并参考以上步骤,创建新的消息通知服务SMN测试事件进行函数测试。