检测到您已登录华为云国际站账号,为了您更好的体验,建议您访问国际站服务网站 https://www.huaweicloud.com/intl/zh-cn
不再显示此消息
APIG实例:选择购买专享版APIG实例创建的APIG实例。
数据保护技术 所有的API请求调用和内部通信均通过TLS 1.2及以上协议进行传输中加密。 父主题: 安全
APIG实例:选择购买专享版APIG实例创建的APIG实例。 图2 AI对话ChatGLM3应用配置 等待应用创建完成,创建成功的应用包含函数服务和专享版API网关资源,其中函数服务的关键资源功能说明请参考表1。
创建APIG触发器 请参见使用APIG触发器,创建APIG触发器,“安全认证”建议选择“None”,方便调试。
SMN触发器、APIG触发器创建以后,不能停用,只能删除。 登录函数工作流控制台,在左侧的导航栏选择“函数 > 函数列表”。 单击函数名称,进入函数详情界面。
资源规划 表1 资源规划详情 产品 配置示例 API网关(APIG) 区域:上海一。 规格:可使用共享版APIG或者创建专享版APIG实例。 函数工作流(FunctionGraph) 区域:上海一。 计费模式:按需计费。 对象存储(OBS) 区域:上海一。
status: ACTIVE eventData: name: APIG_test groupName: APIGroup_xxx auth: IAM
请求url为添加事件源创建的APIG触发器地址。 Body体参考如下格式进行配置,如图3所示,在函数代码中可以根据需要,通过APIGTriggerEvent对象获取相应的值。
事件是指华为云函数工作流上的平台事件,例如:API网关服务和API(例如,REST API)、OBS桶(例如,上传到桶中的镜像)等等。 在Serverless Framework中为华为云函数工作流定义事件时,Framework会自动将事件及其函数转换为相应的云资源。
apigTest(APIGTriggerEvent event, Context context){ System.out.println(event); Map<String, String> headers = new HashMap<String
apigTest(APIGTriggerEvent event, Context context){ System.out.println(event); Map<String, String> headers = new HashMap<String
配置完成后,单击“确定”,完成API触发器创建。 发布API。 单击“触发器”页签下的API名称,跳转至API的总览页面。 图4 API触发器 单击右上方的“编辑”,进入“基本信息”页面。
/code trigger: triggerTypeCode: APIG status: ACTIVE eventData: name: APIG_test groupName:
不配置加密环境变量,则会在界面或API返回结果中明文展示。 在使用触发器、配置VPC访问、使用自定义镜像、挂载SFS等场景下,FunctionGraph需要与其他云服务协同工作,需要由您通过创建云服务委托,让FunctionGraph有权限代替您进行一些资源运维工作。
约束与限制 当通过API访问公有云系统时,需要使用访问密钥(AK/SK)进行身份认证并对请求进行加密,确保请求的机密性、完整性和请求双方身份的正确性。请妥善保存config.yaml配置文件,确保访问密钥不被非法使用。
以上图提示为例,删除失败原因是API组中包含API导致删除失败,通过进入应用程序“总览”页,单击函数服务的“物理资源名称/ID”链接,进入函数详情页,选择“设置”->“触发器”,查看API名称。然后进入API网关服务控制台,将该API下线并删除,最后再删除重试。
选择“apig-event-template”,事件名称输入“helloworld”,测试事件修改为如下所示,完成后单击“创建”。
为API名称,OBS为桶名,TIMER为触发器名称 assume-yes y 选填 选填 在交互时,默认选择y 当前命令还支持部分全局参数(例如-a/--access, --debug等),详情可参考 Serverless Devs 全局参数。
表2 事件模板说明 模板名称 模板说明 API 网关服务(APIG) 模拟APIG事件,触发函数。 API 网关服务(APIG专享版) 模拟APIG(专享版)事件,触发函数。 云审计服务(CTS) 模拟CTS事件,触发函数。 文档数据库服务(DDS) 模拟DDS事件,触发函数。
事件触发,则传递给执行入口的event如下: // JSON.parse(event) { events: { "body": "", "requestContext": { "apiId": "xxx", "requestId"