Mar*_*ark 8 amazon-ec2 amazon-web-services node.js
我在使用Amazon SES发送电子邮件时遇到问题.我有一个Amazon EC2实例.
它在前几天工作但我上周刚注意到所有电子邮件现在都失败了.我尝试使用Node和Amazon SES sdk以及从AWS中发送测试电子邮件.我在Node中有以下代码:
var aws = require('aws-sdk');
// load aws config
aws.config.loadFromPath('email_config.json');
// load AWS SES
var ses = new aws.SES({
apiVersion: '2010-12-01'
});
ses.sendEmail({
Source: from,
Destination: {
ToAddresses: to
},
Message: {
Subject: {
Data: 'Somebody registered'
},
Body: {
Html: {
Data: body,
}
}
}
}, function(err, data) {
console.log('email err is ', err, ' and data is ', data);
});
Run Code Online (Sandbox Code Playgroud)
日志的结果是:
email err is null and data is { ResponseMetadata: { RequestId: 'ad28f526-0b15-11e6-ad87-1108d652684a' },
MessageId: '010101544ebc41b3-f7bd43dd-0505-4eb2-a056-219ce6180fc5-000000' }
Run Code Online (Sandbox Code Playgroud)
但电子邮件没有发送,我接到亚马逊的电子邮件说:
An error occurred while trying to deliver the mail to the following recipients: < my email address >
Run Code Online (Sandbox Code Playgroud)
这包含带有以下文本的附件:
From: < my email address >
To: < my email address >
Subject: Somebody registered
MIME-Version: 1.0
Content-Type: text/html; charset=UTF-8
Content-Transfer-Encoding: 7bit
Message-ID: <010101544ebc41b3-f7bd43dd-0505-4eb2-a056-219ce6180fc5-000000@us-west-2.amazonses.com>
Date: Mon, 25 Apr 2016 18:44:01 +0000
X-SES-Outgoing: 2016.04.25-54.240.27.56
Feedback-ID: 1.us-west-2.GkIUmTTEDEIC5VBoooumwcKSnMDcLT8S4Zd3/deS/BU=:AmazonSES
DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/simple;
s=gdwg2y3kokkkj5a55z2ilkup5wp5hhxx; d=amazonses.com; t=1461609841;
h=From:To:Subject:MIME-Version:Content-Type:Content-Transfer-Encoding:Message-ID:Date:Feedback-ID;
bh=fHqQiK/2DJ+B7zddmElFttCiWFnADDSNj5umLJQCPJs=;
b=ZI/358zmcRHVBKTdA6qbQky5nj5z/YWw215KvkZ+oD73N0booHbl+jx+O05FdcKR
irDjmyEDppGkp7rToZSTt/NHDeRrbERixT/ZCjGo/KOxvShovD7Z5mnDViRmkS5sTz5
qo0oO0NuRz1lGVPkT5ONHNhKhWs7ncC9id0ycm34=
Run Code Online (Sandbox Code Playgroud)
当我实际登录AWS并通过控制台发送测试电子邮件时,我会遇到同样的错误.
我已经验证了发件人的电子邮件地址,并且我已经批准了该地区的发送限制.
任何想法可能是什么?
编辑
我刚刚在我的AWS控制面板> SES主页>域中注意到它说我的域名正在"等待验证".这可能吗?它说我需要添加名称为xxx且值为yyy的TXT DNS记录.我已经在Register365上做了这个.也许我做错了?Register365不提供TXT记录的名称和值字段,只提供"结果"字段.所以我添加了一条带有'result'字段的TXT记录:xxx = yyy.这是正确的方法吗?这是几个星期前的事情,它还在等待验证......
编辑
我已经在我的Register 365控制面板中添加了TXT记录,但我的域名仍然无法验证.记录看起来像:
亚马逊为我提供了以下TXT记录来验证我的域名:
TXT Name*: _amazonses.mydomain.com
TXT Value: u1qHYT6/2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k=
Run Code Online (Sandbox Code Playgroud)
因此,在Register 365控制面板"result"字段中,我添加了name = value形式的记录,即"_amazonses.mydomain.com = u1qHYT6/2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k ="
然后我运行nslookup来查找记录,但得到了消息:
server can't find _amazonses.mydomain.com: NXDOMAIN
Run Code Online (Sandbox Code Playgroud)
我究竟做错了什么?
编辑
我现在已将TXT记录更改为:
但是在3天之后我收到了来自亚马逊的另一封电子邮件,说他们未能验证域名.我现在完全不知所措,我一直试图验证它6周!
我的SES帐户不是沙盒模式 - 我已经被批准通过SES发送电子邮件.我还验证了我的发件人电子邮件地址.
还有其他选择吗?亚马逊SES服务似乎非常可怕.
当我跑的时候:
nslookup -type=TXT _amazonses.redmatterapp.com ns-478.awsdns-59.com
Run Code Online (Sandbox Code Playgroud)
我仍然看到:
server can't find _amazonses.redmatterapp.com: NXDOMAIN
Run Code Online (Sandbox Code Playgroud)
当我跑:
nslookup -type=TXT redmatterapp.com ns-478.awsdns-59.com
Run Code Online (Sandbox Code Playgroud)
我明白了:
Can't find redmatterapp.com: No answer
Run Code Online (Sandbox Code Playgroud)
为什么会这样?我的DNS与Register 365一起使用
编辑
好像我在nslookup上使用的名称服务器是错误的.当我运行nslookup时,我知道得到:
_amazonses.redmatterapp.com text = "u1qN5cbTEDb/2EV9Bhd67YHT5jjqVXKJ8KeXj50k="
Run Code Online (Sandbox Code Playgroud)
哪个看起来正确.然而,我的域名验证仍然失败......
正如迈克尔,SQL Bot指出的那样,左边需要一个主机名(_amazonses),右边需要一个值.这将有助于验证域名.
但是,还有许多其他可能的失败原因.SES仍处于沙盒模式吗?如果是这种情况,您需要验证TO和FROM电子邮件地址.
如果您无法使域验证正常工作,则可能更容易验证个别电子邮件地址.因此,在SES中创建它们,然后完成验证过程.一旦你创建了这些(或者,如果你设法得到域验证)创建一个向你发送电子邮件的SNS主题,然后配置该SNS主题的Bounce,Complaint和Delivery通知 - 你最终应该收到一封电子邮件交付尝试,无论是否成功.
最后要考虑的是您的电子邮件地址已添加到抑制列表中的可能性.如果您生成大量错误,SES会将您添加到"不发送电子邮件"列表中.可以在SES控制台中请求从此列表中删除.
| 归档时间: |
|
| 查看次数: |
692 次 |
| 最近记录: |