[英]Amazon SES emails no longer sending
我在使用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控制面板> 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=
因此,在Register 365控制面板“result”字段中,我添加了name = value形式的記錄,即“_amazonses.mydomain.com = u1qHYT6 / 2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =”
然后我運行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="
哪個看起來正確。 然而,我的域名驗證仍然失敗......
正如邁克爾,SQL Bot指出的那樣,左邊需要一個主機名(_amazonses),右邊需要一個值。 這將有助於驗證域名。
但是,還有許多其他可能的失敗原因。 SES仍處於沙箱模式嗎? 如果是這種情況,您需要驗證TO和FROM電子郵件地址。
如果您無法使域驗證正常工作,則可能更容易驗證個別電子郵件地址。 因此,在SES中創建它們,然后完成驗證過程。 一旦你創建了這些(或者,如果你設法得到域驗證)創建一個向你發送電子郵件的SNS主題,然后配置該SNS主題的Bounce,Complaint和Delivery通知 - 你最終應該收到一封電子郵件交付嘗試,無論是否成功。
最后要考慮的是您的電子郵件地址已添加到抑制列表中的可能性。 如果您生成大量錯誤,SES會將您添加到“不發送電子郵件”列表中。 可以在SES控制台中請求從此列表中刪除。
主機名部分是_amazonses
(左列,數字2旁邊)
值是"u1qHY..."
我認為你在最后一張圖片中走的正確,只有我相信主機名是_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.com設置TXT記錄,這是有道理的,但是而是為http://yourdomain.com設置一個txt記錄,而不是使用值_amazonses.yourdomain.com = u1qHYT6 / 2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =。 這也是其他兩個答案似乎暗示的,這讓我感到更自信。
我最近驗證了我成功工作的公司的域名,在我的域名DNS(作為TXT記錄)中設置如下:
如果您仍然遇到問題,可能值得您閱讀亞馬遜的故障排除頁面 。
添加到我的答案:
我剛剛訪問了我的AWS控制台,如果您打開SES>域並單擊您的域名。 向下滾動然后單擊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記錄未正確設置。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.