函数计算支持HTTP触发器,配置HTTP触发器的函数可以通过HTTP请求被触发执行。函数对HTTP请求进行处理,并将处理结果返回给调用端。本文介绍如何在函数计算控制台配置HTTP触发器并使用HTTP请求触发。
前提条件
步骤一:创建触发器
登录函数计算控制台,在左侧导航栏,单击函数。
在顶部菜单栏,选择地域,然后在函数页面,单击目标函数。
在函数详情页面,选择配置页签,在左侧导航栏,单击触发器,然后单击创建触发器。
在创建触发器面板,填写相关信息,然后单击确定。
配置项
操作
本文示例
触发器类型
选择HTTP 触发器。
HTTP 触发器
名称
填写自定义的触发器名称。
http-trigger
版本或别名
默认值为LATEST,如果您需要创建其他版本或别名的触发器,需先在函数详情页的版本或别名下拉列表选择该版本。关于版本和别名的简介,请参见版本管理和别名管理。
LATEST
请求方法
指定可以通过哪些方法触发器该HTTP触发器。
GET, POST, PUT, DELETE
禁用公网访问 URL
默认选择否,即允许公网域名访问该触发器。
如果选择是,创建的HTTP触发器将不提供默认的公网域名。此时,如果通过公网域名来调用函数,将会提示错误
access denied due to function internet URL is disable
。通过自定义域名的访问,则不受影响。否
认证方式
选择函数计算对HTTP请求的认证方式。取值说明如下:
无需认证:无需对HTTP请求进行身份认证,支持匿名访问,任何人可发起HTTP请求调用您的函数。
签名认证:需要对HTTP请求进行身份认证。关于签名认证的示例代码,请参见通过签名访问HTTP触发器地址。
JWT 认证:需要对HTTP请求进行JWT认证。更多信息,请参见为HTTP触发器配置JWT认证鉴权。
无需认证
创建完成后,您可以根据情况对HTTP触发器的配置项进行修改,包括版本或别名、请求方法、禁用公网访问 URL和认证方式。
步骤二:编写并部署代码
完成创建HTTP触发器后,您可以开始编写函数代码。
在函数详情页面,单击代码页签,在代码编辑器中编写代码,然后单击部署代码。关于示例代码,请参见函数计算文档 中不同运行时的请求处理程序文档。
步骤三:测试函数
方式一:使用控制台测试函数
在函数详情页面,单击代码页签。
同步调用
单击测试函数。
异步调用
单击测试函数右侧的图标,选择异步调用,然后单击测试函数。
执行完成后,在代码页签,您可以查看执行结果。
方式二:使用cURL测试函数
在函数详情页面,单击配置页签,然后在左侧导航栏,选择触发器。在HTTP触发器的配置信息里选择公网访问地址复制用于以下测试。
同步调用
在命令行执行如下命令,执行完成后会返回执行结果。
curl -v https://http-***.cn-shenzhen.fcapp.run/$path
异步调用
在命令行执行如下命令,执行完成后会返回函数计算接收请求的结果。其中状态码
202
表示请求成功,其余表示请求出现错误,关于错误码的解释,请参见常见问题(错误排查)。curl -v -H "X-Fc-Invocation-Type: Async" https://http-***.cn-shenzhen.fcapp.run/$path
(可选)使用API网关保护函数
默认情况下,函数计算不会对HTTP请求进行身份验证,支持匿名访问函数,即任何人都可以发送HTTP请求调用您的函数。为防止非法用户访问您的函数,引起不必要的资源浪费或安全隐患,您可以开启身份认证的同时将HTTP函数与API网关进行对接,利用API网关的IP访问控制插件、JWT认证插件或BasicAuth插件等保护您的HTTP函数。
在函数计算控制台找到目标函数,在函数详情页面单击配置页签,在左侧导航栏选择触发器,然后单击编辑。
在编辑触发器面板,禁用公网访问 URL选择为是。
登录API网关控制台,切换至HTTP函数所在地域。
创建分组。具体操作,请参见创建分组。
将您的域名通过CNAME方式解析到API网关提供的二级域名上。具体操作,请参见CNAME绑定域名。
创建API。
主要配置项设置如下,其余配置项下的设置选择默认值或者根据实际情况填写即可。更多信息,请参见创建 API。
安全认证:选择无认证,后续会使用插件进行认证。
请求Path:填写根目录/,然后选中匹配所有子路径。
HTTP Method:选择ANY。
入参请求模式:选择入参透传。
后端服务类型:选择函数计算。
产品版本:选择函数计算3.0。
函数类型:选择HTTP函数。
触发器路径:填写函数计算的HTTP触发器的内网访问地址。
ContentType:选择透传客户端ContentType头。
发布API。单击已创建的API右侧操作列的发布,选择线上环境,然后单击发布。
创建一个类型为后端签名的插件,
key
和secret
分别配置为您的阿里云账号的AccessKey ID
和AccessKey Secret
。然后绑定您刚才创建的API。具体操作,请参见插件概述。
完成以上步骤后,您可以通过自己的域名访问HTTP函数。您还可以创建以下插件,并将其绑定到您的API,保护您的HTTP函数。
错误排查
错误主要分为以下两种。
请求错误是指发送的Request不符合标准,在Response里报错状态码为4xx。
函数错误即编写的函数有问题,会报5xx状态码。
下表描述请求错误和函数错误可能出现的场景,以便您迅速排查问题。
错误类型 | HTTP状态码 | 原因分析 | 是否计费 |
请求错误 | 400 | 您的请求超过Request限制项的限制。更多信息,请参见HTTP触发器概述。 | 否 |
400 | 调用需要身份认证的函数的Request没有传入Date信息或Authorization信息。 | 否 | |
403 | 调用需要身份认证的函数的Request的签名错误,即Authorization不正确。由于Date参与签名计算,且超过15 min,签名失效,一种常见的原因是使用需要访问认证的HTTP触发器,Request header中发送的Date据当前时间超过15 min,导致签名失效。 | 否 | |
403 | 您的Request请求使用HTTP触发器中未配置的请求方法。例如,HTTP触发器中的请求方法只配置GET方法,却发送POST方法的HTTP请求。 | 否 | |
404 | 向没有设置HTTP触发器的函数发送HTTP请求。 | 否 | |
用户流控 | 429 | 用户被流控,可减小并发量或者联系函数计算开发团队提高并发度。 | 否 |
函数错误 | 502 | 函数的返回值超过Response限制项的限制。更多信息,请参见HTTP触发器概述。 | 是 |
502 | 函数代码有语法错误或者异常。 | 是 | |
502 | 向未使用HTTP入口函数的函数发送HTTP请求。 | 是 | |
系统错误 | 500 | 函数计算系统错误,可重试解决。 | 否 |
系统流控 | 503 | 函数计算系统流控。可用指数退避方式重试。 | 否 |
如果问题还未能解决,请加入钉钉用户群(钉钉群号:64970014484),联系函数计算工程师及时沟通处理。。