您可以通过使用消息服务MNS创建事件通知规则,以消息的方式主动推送到指定的接收端,来关注邮件推送事件。本文介绍邮件推送事件通知的适用场景、事件规则、操作步骤等内容。
如果您在邮件推送服务控制台打开异步通知功能,消息服务MNS支持将邮件推送的结果以消息的方式继续异步通知。您可以通过创建事件通知的规则,来指定在邮件推送过程中触发不同的事件时,将邮件推送的结果消息推送到对应的接收端中。示意图如下:

适用场景
您可以通过使用消息服务MNS解决以下问题:
- 异步获取邮件推送的结果,再根据业务需求进行相应的处理。例如重新发送。
- 对于大批量的邮件通知的场景,可异步统计推送情况。
- 自动处理结果消息,对推送情况进行监控。例如在突发的大量邮件推送失败时,您可以第一时间知晓。
- 结果消息可以通过多种方式推送到不同的接收端,以进行不同的统计处理。例如多个业务部门均关心该数据。
- 如果A将推送的权限授予B,A可以通过该方式来知晓B推送短信的情况。
事件规则
事件通知规则由以下两部分组成:
- 事件类型
事件通知按地域提供服务。创建规则时,关注某个(些)事件就是指关心这个地域的邮件推送过程中产生的所有该类型的事件。邮件推送的事件有以下两种:
事件类型 描述 Deliver:SendSuccessfully 邮件推送成功。 Deliver:SendFailed 邮件推送失败。 - 消息接收终端
消息接收终端创建规则时,消息的接收终端有以下设置方式:
- 指定接收消息的HTTP服务或者消息服务MNS的队列
系统会自动创建一个主题,并且以指定的HTTP服务或者队列作为Endpoint创建相应的订阅。如果没有提前创建主题,推荐使用这种方式。
- 直接指定主题
如果规则匹配,消息会发布到主题中。您可以选择已有的主题,在该主题上创建订阅,指定通过何种方式将消息推送到指定的接收端。
说明- 如果您指定了不存在的主题,消息无法正常推送。
- 不要选择短信专用的主题sms.xxx作为消息接收端,短信专用主题仅支持短信推送。
- 如果直接指定主题,您只能指定一个主题。
- 指定接收消息的HTTP服务或者消息服务MNS的队列
注意事项
关于创建事件规则,您要注意以下事项:
- 事件通知规则只能由主账号创建。
- 事件通知规则创建完成,约10分钟生效。
- 事件通知规则指定消息接收端时,如果选择主题,与选择其他的接收终端是互斥的。即如果选择了主题,那只能继续选择主题;如果选择了非主题的终端,那只能选择非主题的终端。
- 事件通知规则创建时,如果选择主题作为接收终端,您需要创建对应的订阅定义推送方式。
- 事件通知规则创建时,如果选择非主题作为接收终端,会自动创建主题和对应的订阅。
- 事件通知规则支持创建和删除,暂时不支持修改。
邮件推送异步通知消息
邮件推送的结果消息格式包含以下字段:
字段名 | 描述 |
---|---|
env_id | 系统内ID,用于反馈查询问题。 |
msg_id | 邮件原文中的Message-ID字段。 |
account | 发件人账户。 |
from | 发件人地址。 |
rcpt | 收件人地址。 |
recv_time | 邮件接收入队时间。 |
end_time | 邮件投递完成时间。 |
status | 投递完成结果状态:
|
event | 触发的事件。 |
region | 事件规则所在地域。 |
err_code | 投递完成时接收方ESP返回码。 |
err_msg | 投递完成时接收方ESP返回信息。 |
发送成功和发送失败时,消息中的字段都是一样的,格式如下:
env_id=$env_id&msg_id=$msg_id&account=$account&from=$from&rcpt=$rcpt&recv_time=$time&end_time=$time&status=$status&event=$event®ion=$region&err_code=$err_code&err_msg=$err_msg
错误说明
错误信息请参见邮件推送常见退信代码及处理方法。重点关注接收方常见退信代码。
此外,API级别的错误(消息服务MNS邮件订阅推送时出错)请参见:
- 单独推送请参见SingleSendMail。
- 批量推送请参见BatchSendMail。
消息示例
- 发送成功示例如下:
env_id=457323378&msg_id=77041400535408&account=test@test.com&from=test@test.com&rcpt=abc@abc.com&recv_time=2017-04-14 11:44:47&end_time=2017-04-14 11:44:48&status=0&event=deliver®ion=cn-hangzhou&err_code=250&err_msg=250 Send Mail OK
- 发送失败示例如下:
env_id=457323379&msg_id=77041400535409&account=test@test.com&from=test@test.com&rcpt=abc@abc.com&recv_time=2017-04-14 11:44:48&end_time=2017-04-14 11:44:49&status=2&event=deliver®ion=cn-hangzhou&err_code=550&err_msg=550 No Such User
操作步骤
- 登录消息服务MNS控制台。
- 在顶部菜单栏,选择地域。
- 在左侧导航栏,单击事件通知。
- 在事件通知页面的右上角,单击创建规则。
- 在创建规则对话框,填写相关信息,然后单击创建规则。
- 接收异步通知消息(队列为例)。
推送邮件后,可以根据对应事件规则中的描述,在指定的消息接收终端查看到结果消息。例如创建规则时,如果指定将消息发送到队列中,那么可以在控制台中对应的队列查看消息内容。
- 在队列页面,找到接收终端指定的队列,在其右侧操作列单击接收消息。
- 在接收消息对话框,清除Base64解码,查看事件通知的消息内容。
更多信息
- 消息通知是基于消息服务MNS的主题实现的,支持多种推送方式,详情请参见推送类型。
- 接收消息的HTTP服务搭建请参见主题使用手册和HttpEndpoint。
- 从对应的队列中获取通知消息的方式请参见消费消息示例代码。
- 使用SDK从对应队列中接收异步回调结果消息的示例代码可参见以下文档:
在文档使用中是否遇到以下问题
更多建议
匿名提交