检测到您已登录华为云国际站账号,为了您更好的体验,建议您访问国际站服务网站 https://www.huaweicloud.com/intl/zh-cn
不再显示此消息
environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak := os.Getenv("CLOUD_SDK_AK") sk := os.Getenv("CLOUD_SDK_SK")
environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak := os.Getenv("CLOUD_SDK_AK") sk := os.Getenv("CLOUD_SDK_SK")
FunctionGraph保证每个函数实例启动后只会成功执行一次initializer 。如果执行失败,那么该函数实例执行失败,选取下一个实例重新执行,最多重试3次。一旦执行成功,在该实例的生命周期内不会再执行initializer,收到Invoke请求之后只执行请求处理函数。 initializer入口命名
package-functionname memoryUsed 函数执行内存使用 该指标用于统计函数执行内存使用量 MB - 0 - float package-functionname duration_p500 函数执行时间p50 该指标用于统计函数执行时间的p50 毫秒 - 0 - float package-functionname
environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak := os.Getenv("CLOUD_SDK_AK") sk := os.Getenv("CLOUD_SDK_SK")
创建测试事件。 在事件模板中选择“timer-event-template”,并保存。 单击“测试”并执行。 函数执行结果分为三部分,分别为函数返回(由callback返回)、执行摘要、日志输出(由System.out.println()方法获取的日志方法输出)。 父主题: 开发事件函数
常规设置”,如图3所示,可以查看和修改“函数执行入口”信息,修改完成后单击“保存”。 图3 函数执行入口 在“代码”页签,请根据设置的函数执行入口修改对应的文件名和执行函数名,如图4所示。 图4 文件名和执行函数名 在线编辑代码区域管理 如图5所示,在线编辑代码区域支持类似工程方式的管理,支持
environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak := os.Getenv("CLOUD_SDK_AK") sk := os.Getenv("CLOUD_SDK_SK")
emoTestB)的完整函数执行过程。 图7 函数A调用函数B详情 ①函数A方法的总耗时。 ②通过HTTP请求调用函数B。 ③进入函数B。 ④执行executeQuery。 ⑤执行Select查询语句。 如下是在函数首次调用包含冷启动的的完整函数执行过程。 图8 示例 Spans动作说明如下:
environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak := os.Getenv("CLOUD_SDK_AK") sk := os.Getenv("CLOUD_SDK_SK")
初始化:在此阶段,FunctionGraph会尝试解冻之前的执行环境,若没有可解冻的环境,FunctionGraph会进行资源创建,下载函数代码,初始化扩展和Runtime,然后开始运行初始化代码(主程序外的代码)。 执行:在此阶段,实例接收事件后开始执行函数。函数运行到完成后,实例会等待下个事件的调用。
单个账户下最大允许创建的函数个数 400 单个账户下最大允许部署包大小 10GB 单个账户下函数并发执行数 100 如果您的业务有更大的并发执行数需求,请提交工单申请。 单个账户下创建预留实例个数 90(单个租户下函数并发执行数*90%) 如果您的业务有更大的预留实例个数需求,请提交工单申请。 单个函数下最大允许创建的标签个数
environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak := os.Getenv("CLOUD_SDK_AK") sk := os.Getenv("CLOUD_SDK_SK")
本章通过图片处理的例子解释该方案的实现机制。 如果需要驱动一个工作流执行,工作流系统需要处理两个部分: 控制流:控制工作流的步骤间流转,以及步骤对应的 Serverless 函数的执行。确保步骤与步骤之间有序执行。 数据流:控制整个工作流的数据流转,通常来说上一个步骤的输出是下一
打zip包,必须包含“bootstrap”可执行引导文件。 将工程打成ZIP包,直接上传到OBS存储桶。 Cangjie 不支持该方式 必须在编译之后打zip包,编译后的二进制文件必须与执行函数入口保持一致,例如二进制名称为libuser_func_test_success.so,则执行入口为libuser_func_test_success
基于已禁用的“latest”版本重新发布新版本,发布后的新版本也处于禁用状态且不能启用。 当函数处于禁用状态时可以修改代码,不能执行函数。 禁用函数 用户可以根据实际情况将函数禁用,禁用期间函数不能执行。 登录函数工作流控制台,在左侧导航栏选择“函数 > 函数列表”,进入函数列表页面。 在“函数列表”,单击函数名称,进入“函数详情”页面。
文件时,单函数的执行入口文件必须在根目录,确保解压后直接出现函数的执行入口文件,代码才能正常部署,如需修改函数执行入口,请参见修改函数执行入口。 约束与限制 请参考表1查看所使用的运行时是否支持从OBS上传。不同运行时语言的函数执行入口信息,请参见表1中“函数执行入口”参数介绍。
operations and the Users database posts/ serverless.yml # Contains 4 functions that do Posts CRUD operations and the Posts database comments/ serverless
使用Terraform命令创建函数 进入文件路径,执行terraform init命令初始化一个包含Terraform代码的工作目录。 执行terraform apply命令,在Enter a value: 处输入yes。 执行成功代表函数创建完成。 父主题: 创建函数
步骤三:调用函数 在父函数的函数详情页,单击“测试”,进行父函数调用。 查看执行结果。 父函数的执行结果显示“成功”,返回“200”。 图3 父函数执行历史 子函数的日志中,显示被调用的日志。 图4 子函数执行历史 父主题: 应用示例