如何解决如何在 AWS SAM 模板中的 API 网关触发的 lambda 资源中添加事件
我正在尝试创建一个 AWS SAM 模板,其中包含一个应由 API 网关触发的 lambda。
SAM 模板仅用于 API 网关,不用于 API 网关。 API 网关将手动创建,并在部署 SAM 模板之前存在。
Events:
APIName:
Type: Api
Properties:
Method : post
Path : /group/user
RestApiId:
Ref: MyApi
可以查看here的示例。
我不明白的是,我应该如何确切地在我的用例中使用它。
我的问题:
- API 名称:这里放什么?我使用了已在 AWS 帐户中创建的确切 API 名称,但收到事件 ID 无效的错误消息。
- 如何唯一标识我的 API? :假设我们有两个具有相同路径
/sendMesage
的 API,那么模板如何知道要引用哪个 API 网关?我认为它与 RestApiId 有关,但我不确定,因为它不是必填字段。 - 我们可以不链接现有的 API 网关吗? :我认为这里可能存在的一个可能问题是,我们实际上无法将现有 API 网关链接为 lambda 的触发器,该 lambda 将在部署 SAM 堆栈后创建。但这是有局限性的,我不确定这是否属实。
解决方法
我会一一解答,希望对你有所帮助
API 名称:要在这里放什么? 这只是您正在创建的 API 事件的标识符。我通常对端点使用某种形式的描述。无论你最终做什么,尽量有一些约定,否则它会变得难以阅读(Http 动词然后是动作,例如 GetAllUsers)
如何唯一标识我的 API? :
感觉就像你实际上有两个不同的职责,因此这里可能有两个不同的路径名。如果 sendMessage 可以向群组或用户发送消息,那么您可以使用 sendMessageToGroup
和 sendMessageToUser
,从而使它们更加明确。
我们可以不链接现有的 API 网关吗? : 看起来不是 judging by the docs,但我可能错了。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。