我在使用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);
});
日志的结果是:
email err is null and data is { ResponseMetadata: { RequestId: 'ad28f526-0b15-11e6-ad87-1108d652684a' },
MessageId: '010101544ebc41b3-f7bd43dd-0505-4eb2-a056-219ce6180fc5-000000' }
但是电子邮件没有发送,然后我收到亚马逊的电子邮件说:
An error occurred while trying to deliver the mail to the following recipients: < my email address >
这包含带有以下文字的附件:
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=
当我实际登录AWS并通过控制台发送测试电子邮件时,我会遇到同样的错误。
我已经验证了发件人的电子邮件地址,并且我已经批准了该地区的发送限制。
任何想法可能是什么?
修改
我刚在AWS控制面板中注意到&gt; SES主页&gt;域名表示我的域名正在等待验证&#39;。这可能吗?它说我需要添加名称为xxx且值为yyy的TXT DNS记录。我已经在Register365上做了这个。也许我做错了? Register365不提供TXT记录的名称和值字段,只有&#39;结果&#39;领域。所以我添加了TXT记录&#39;结果&#39;领域:xxx = yyy。这是正确的方法吗?这是几个星期前的事情,它还在等待验证......
修改
我已将TXT记录添加到Register 365控制面板,但我的域名仍然无法验证。记录如下:
亚马逊向我提供了以下TXT记录来验证我的域名:TXT Name*: _amazonses.mydomain.com
TXT Value: u1qHYT6/2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k=
所以在Register 365控制面板&#34;结果&#34;字段我已经在表格中添加了记录名=值,即#34; _amazonses.mydomain.com = u1qHYT6 / 2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =&#34;
然后我运行了nslookup来查找记录,但收到了消息:
server can't find _amazonses.mydomain.com: NXDOMAIN
我做错了什么?
修改
我现在已将TXT记录更改为:
但是在3天之后我收到了来自亚马逊的另一封电子邮件,说他们未能验证域名。我现在完全感到困惑,我已经试图验证它6周了!
我的SES帐户未处于沙盒模式 - 我已获准通过SES发送电子邮件。我还验证了我的发件人电子邮件地址。
我还有其他选择吗?亚马逊SES服务似乎非常可怕。
当我跑步时:
nslookup -type=TXT _amazonses.redmatterapp.com ns-478.awsdns-59.com
我仍然看到:
server can't find _amazonses.redmatterapp.com: NXDOMAIN
当我跑步时:
nslookup -type=TXT redmatterapp.com ns-478.awsdns-59.com
我明白了:
Can't find redmatterapp.com: No answer
为什么会这样?我的DNS使用Register 365
修改
似乎我在nslookup中使用的名称服务器是错误的。当我运行nslookup时,我知道得到:
_amazonses.redmatterapp.com text = "u1qN5cbTEDb/2EV9Bhd67YHT5jjqVXKJ8KeXj50k="
哪个看起来正确。然而,我的域名验证仍然失败......
答案 0 :(得分:6)
作为迈克尔,SQL Bot指出,你需要左边的主机名(_amazonses)和右边的值。这将有助于验证域名。
然而,还有许多其他可能的失败原因。 SES仍处于沙箱模式吗?如果是这种情况,您需要验证TO和FROM电子邮件地址。
如果您无法使域验证正常运行,则可能更容易验证个别电子邮件地址。因此,在SES中创建它们,然后完成验证过程。一旦你创建了这些(或者,如果你设法得到域验证)创建一个向你发送电子邮件的SNS主题,然后配置该SNS主题的Bounce,Complaint和Delivery通知 - 你最终应该收到一封电子邮件交付尝试,无论是否成功。
最后要考虑的是您的电子邮件地址已添加到抑制列表中的可能性。如果您产生了很多错误,SES会将您添加到&#34;不要发送电子邮件&#34;名单。可以在SES控制台中请求从此列表中删除。
答案 1 :(得分:4)
主机名部分为_amazonses
(左列,数字2旁边)
值为"u1qHY..."
答案 2 :(得分:3)
我认为你在最后一张图片中走的正确,只有我相信主机名是_amazonses,并且u1qHYT6 / 2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =结果,而不是以“_amazonses.yourdomain”的形式将所有内容放在结果字段中.COM = u1qHYT6 / 2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =”。 Iiuc,我的想法是AWS会卷曲_amazonses.yourdomain.com,期望你的密钥可以作为TXT文件服务,但是目前你正在提供一个TXT文件,内容为_amazonses.yourdomain.com = u1qHYT6 / 2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =(I不能完全阅读,因为它被切断了;原谅我的猜测,而不是在你的域名网站上。
我相信这是因为您收到错误NXDOMAIN,这意味着域_amazonses.yourdomain.com不存在,如果您没有为_amazonses.yourdomain设置TXT记录,这是有道理的。但是,而是设置http://yourdomain.com的txt记录而不是值_amazonses.yourdomain.com = u1qHYT6 / 2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =。这也是其他两个答案似乎所暗示的,这让我感到更自信。
答案 3 :(得分:2)
我最近验证了我成功运营的公司的域名,在我的域名DNS(作为TXT记录)中设置如下:
如果您仍然遇到问题,可能值得您阅读Amazon's troubleshooting page。
添加到我的回答:
我刚刚在我的AWS控制台中查看过,如果您打开SES&gt;域名并单击您的域名。向下滚动然后点击DKIM,我必须在那里验证更多:
并将它们添加为CNAME记录,如下所示:
人们忘记这一过程的一件事是,亚马逊要求您即使在验证后也要保留TXT记录。否则他们将撤销域名。
希望这有帮助!
又一个编辑(抱歉)
当我运行nslookup -type=TXT _amazonses.redmatterapp.com ns-1471.awsdns-55.org
尝试找到你的TXT记录时,它会回来:
Server: ns-1471.awsdns-55.org
Address: 205.251.197.191#53
** server can't find _amazonses.redmatterapp.com: NXDOMAIN
这表明TXT记录未正确设置。