本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
SNS
SNS (sns) 操作将 MQTT 消息中的数据作为 Amazon Simple Notification Service(Amazon SNS)推送通知发送。
您可以按照教程执行操作,该教程向您说明如何使用 SNS 操作创建和测试规则。有关更多信息,请参阅 教程:发送 Amazon SNS 通知。
注意
SNS 操作不支持Amazon SNS FIFO(先进先出)主题。由于规则引擎是一个完全分布式服务,因此无法保证触发 SNS 操作时的消息顺序。
要求
此规则操作具有以下要求:
-
Amazon IoT可以代入执行
sns:Publish操作的 IAM 角色。有关更多信息,请参阅 授予Amazon IoT规则所需的访问权限。在Amazon IoT控制台中,您可以选择或创建Amazon IoT允许执行此规则操作的角色。
-
如果您使用Amazon KMS客户托管Amazon KMS key来加密 Amazon SNS 中的静态数据,则该服务必须有权代表呼叫Amazon KMS key者使用这些数据。有关更多信息,请参阅《Amazon Simple Notification Service 开发人员指南》中的密钥管理。
Parameters
使用此操作创建Amazon IoT规则时,必须指定以下信息:
示例
以下 JSON 示例在Amazon IoT规则中定义了 SNS 操作。
{ "topicRulePayload": { "sql": "SELECT * FROM 'some/topic'", "ruleDisabled": false, "awsIotSqlVersion": "2016-03-23", "actions": [ { "sns": { "targetArn": "arn:aws:sns:us-east-2:123456789012:my_sns_topic", "roleArn": "arn:aws:iam::123456789012:role/aws_iot_sns" } } ] } }
以下 JSON 示例在Amazon IoT规则中定义了带有替换模板的 SNS 操作。
{ "topicRulePayload": { "sql": "SELECT * FROM 'some/topic'", "ruleDisabled": false, "awsIotSqlVersion": "2016-03-23", "actions": [ { "sns": { "targetArn": "arn:aws:sns:us-east-1:123456789012:${topic()}", "messageFormat": "JSON", "roleArn": "arn:aws:iam::123456789012:role/aws_iot_sns" } } ] } }
另请参阅
-
《Amazon Simple Notification Service 开发人员指南》中的什么是 Amazon Simple Notification Service?