- 最新动态
- 功能总览
- 产品介绍
- 计费说明
- 快速入门
-
用户指南
- 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时如何处理?
- 配置触发器
- 配置依赖包
-
产品咨询
- 视频帮助
- 文档下载
- 通用参考
链接复制成功!
Node.js函数开发概述
FunctionGraph当前支持以下Node.js运行环境:
- Node.js 6.10
- Node.js 8.10
- Nodejs 10.16
- Nodejs 12.13
- Node.js 14.18
- Node.js 16.17
- Node.js 18.15
- Node.js 20.15
Node.js函数接口定义
Node.js 6.10函数接口定义
export.handler = function(event, context, callback)
- 入口函数名(handler):入口函数名称, 需和函数执行入口处用户自定义的入口函数名称一致。
- 执行事件(event):函数执行界面由用户输入的执行事件参数, 格式为JSON对象。
- 上下文环境(context):Runtime提供的函数执行上下文,其接口定义在SDK接口说明。
- 回调函数(callback):callback方法完整声明为callback(err, message),用户通过此方法可以返回err和message至前台结果显示页面。具体的err或message内容需要用户自己定义,如字符串。
Node.js 8.10及以后版本Runtime函数接口定义
Node.js 8.10及以后版本Runtime除了兼容Node.js 6.10 Runtime函数的接口定义规范,还支持使用async的异步形式作为函数入口。通过return进行返回。
exports.handler = async (event, context, callback[可选]) => { return data;}
Node.js函数的函数执行入口参数格式为:[文件名].[函数名],请通过FunctionGraph控制台进行函数执行入口配置。例如创建函数时设置函数执行入口为index.handler,那么FunctionGraph会去加载index.js中定义的handler函数。
Node.js的Initializer入口介绍
关于函数初始化入口Initializer的具体介绍请参考函数初始化入口Initializer。
Node.js的Initializer入口格式为:[文件名].[initializer名]
示例:实现initializer接口时指定的Initializer入口为“index.initializer”,那么函数工作流服务会去加载index.js中定义的initializer函数。
在函数工作流服务中使用Node.js编写initializer逻辑,需要定义一个Node.js函数作为initializer入口,以下为initializer的简单示例。
exports.initializer = function(context, callback) {
callback(null, '');
};
- 函数名
exports.initializer需要与实现initializer接口时的Initializer字段相对应。
示例:创建函数时指定的Initializer入口为index.initializer,那么FunctionGraph会去加载index.js中定义的initializer函数。
- context参数
context参数中包含一些函数的运行时信息。例如:request id、临时AccessKey、function meta等。
- callback参数
callback参数用于返回调用函数的结果,其签名是function(err, data),与Nodejs中惯用的callback一样,它的第一个参数是error,第二个参数data。如果调用时error不为空,则函数将返回HandledInitializationError,由于屏蔽了初始化函数的返回值,所以data中的数据是无效的,可以参考上文的示例设置为空。
Node.js Runtime集成的三方件
名称 |
功能 |
版本号 |
---|---|---|
q |
异步方法封装。 |
1.5.1 |
co |
异步流程控制。 |
4.6.0 |
lodash |
常用工具方法库。 |
4.17.10 |
esdk-obs-nodejs |
OBS SDK。 |
2.1.5 |
express |
极简web开发框架。 |
4.16.4 |
fgs-express |
在FunctionGraph和API Gateway之上使用现有的Node.js应用程序框架运行无服务器应用程序和REST API 。提供的示例允许您使用Express框架轻松构建无服务器Web应用程序/服务和RESTful API 。 |
1.0.1 |
request |
简化HTTP调用,支持HTTPS并默认遵循重定向 |
2.88.0 |
SDK接口
Context类中提供了上下文方法供您在函数代码中使用,其声明和功能如表2所示。
方法名 |
方法说明 |
---|---|
getRequestID() |
获取请求ID。 |
getRemainingTimeInMilliSeconds () |
获取函数剩余运行时间。 |
getAccessKey() |
获取用户委托的AccessKey(有效期24小时),使用该方法需要为函数配置委托。 当前函数工作流已停止维护Runtime SDK 中getAccessKey接口,您将无法使用getAccessKey获取临时AK。 |
getSecretKey() |
获取用户委托的SecretKey(有效期24小时),使用该方法需要为函数配置委托。 当前函数工作流已停止维护Runtime SDK 中getSecretKey接口,您将无法使用getSecretKey获取临时SK。 |
getSecurityAccessKey() |
获取用户委托的SecurityAccessKey(有效期24小时),缓存时间为10分钟,即10分钟内再次获取的返回内容相同,使用该方法需要为函数配置委托。 |
getSecuritySecretKey() |
获取用户委托的SecuritySecretKey(有效期24小时),缓存时间为10分钟,即10分钟内再次获取的返回内容相同,使用该方法需要为函数配置委托。 |
getSecurityToken() |
获取用户委托的SecurityToken(有效期24小时),缓存时间为10分钟,即10分钟内再次获取的返回内容相同,使用该方法需要为函数配置委托。 |
getUserData(string key) |
通过key获取用户通过环境变量传入的值。 |
getFunctionName() |
获取函数名称。 |
getRunningTimeInSeconds () |
获取函数超时时间。 |
getVersion() |
获取函数的版本。 |
getMemorySize() |
分配的内存。 |
getCPUNumber() |
获取函数占用的CPU资源。 |
getPackage() |
获取函数组。 |
getToken() |
获取用户委托的Token(有效期24小时),使用该方法需要为函数配置委托。 |
getLogger() |
获取context提供的logger方法,返回一个日志输出类,通过使用其info方法按“时间-请求ID-输出内容”的格式输出日志。 如调用info方法输出日志: logg = context.getLogger() logg.info("hello") |
getAlias() |
获取函数的别名。 |
如图1所示,可在函数工作流控制台代码编辑器中使用context类。
相关文档
- 使用Node.js开发事件函数,请参见开发Node.js事件函数。
- 使用Node.js运行时语言开发HTTP函数,请参见使用Node环境开发HTTP函数。
- 为Node.js函数制作依赖包,请参见为Node.js函数制作依赖包。
- 关于函数开发的更多说明,如函数支持的运行时、函数支持的触发事件、函数工程打包规范以及如何在函数中引入动态链接库,请参见函数开发概述。