2016-04-27 207 views
8

我在使用Amazon SES發送電子郵件時遇到問題。我有一個Amazon EC2實例。Amazon SES郵件不再發送

它工作了幾天,但我剛剛注意到上週所有的電子郵件現在都失敗了。我曾嘗試使用Node和Amazon SES sdk進行發送,並從AWS內部發送測試電子郵件。我在節點下面的代碼:

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' } 

但電子郵件犯規deliever,我再從亞馬遜收到一封電子郵件,說:

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: <[email protected]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記錄的名稱和值域,只有'結果'域。所以我添加了一個TXT記錄,其結果字段爲:xxx = yyy。這是正確的方法嗎?這星期前,雖然其仍在等待驗證....

編輯

因爲我已經加入了TXT記錄我的註冊365的控制面板,而我的域無法驗證。該記錄是這樣的:

enter image description here

亞馬遜給我提供了以下TXT記錄來驗證我的域名:

TXT Name*: _amazonses.mydomain.com 
TXT Value: u1qHYT6/2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k= 

所以在註冊365控制面板中的「結果」字段我已經添加了記錄在表格名稱=值即「_amazonses.mydomain.com = u1qHYT6/2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =」

我然後跑nslookup來查找記錄,但得到的消息:

server can't find _amazonses.mydomain.com: NXDOMAIN 

我在做什麼錯?

編輯

我現在已經改變了TXT記錄:

enter image description here

但後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是註冊365

編輯

好像我用用NSLOOKUP是錯誤的域名服務器。當我運行nslookup,我知道得到:

_amazonses.redmatterapp.com text = "u1qN5cbTEDb/2EV9Bhd67YHT5jjqVXKJ8KeXj50k=" 

看起來不錯。然而,仍然驗證了我的域失敗...

+0

'TXT'記錄需要雙引號:'「xxx = yyy」'。 –

+0

好的將嘗試 – Mark

+0

這沒有工作... – Mark

回答

4

的主機名部分_amazonses(左列,旁邊的2號)

值是"u1qHY..."

+0

事實上,我認爲這已經修復了,但AWS仍然無法驗證我的域名 – Mark

6

正如邁克爾,在SQL博特指出,你需要一個主機名(_amazonses)在左邊,並在右邊的值。這將有助於驗證域名。

但是,還有其他一些可能的失敗原因。 SES仍然處於沙箱模式嗎?如果是這種情況,則需要驗證TO和FROM電子郵件地址。

如果您無法使域驗證正常工作,驗證個人電子郵件地址可能會更容易。所以在SES中創建它們,並通過驗證過程。一旦你創建了這些(或者,如果你設法驗證域名)創建一個SNS主題給你發送電子郵件,然後配置該SNS主題的Bounce,Complaint和Delivery通知 - 你最終應該收到每封電子郵件交付嘗試,無論它是否成功。

最後要考慮的是您的電子郵件地址已被添加到抑制列表的可能性。如果您生成很多錯誤,SES會將您添加到「不要發送電子郵件」列表中。有能力請求從SES控制檯中的此列表中刪除。

3

我覺得你那最後的圖像在正確的軌道上,只有我相信主機名是_amazonses和u1qHYT6/2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =是不是把一切都在結果字段的形式「_amazonses結果。 yourdomain.com = u1qHYT6/2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =」。 Iiuc的想法是,AWS將捲曲_amazonses.yourdomain.com,期待您的密鑰作爲TXT文件,但目前您正在使用內容提供TXT文件_amazonses.yourdomain.com = u1qHYT6/2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =(I不能完全閱讀,因爲它的切斷;請原諒我的猜測)在yourdomain.com上。

我相信這是你得到的錯誤NXDOMAIN,這意味着域_amazonses.yourdomain.com不存在,這是有道理的,如果你沒有設置_amazonses.yourdomain的TXT記錄.com,而是建立一個http://yourdomain.com的txt記錄,而不是值_amazonses.yourdomain.com = u1qHYT6/2KV9Kl1VLKsApXjwcPqVXKJ8KeXj50k =。其他兩個答案似乎也表明了這一點,這讓我感覺更加自信。

+0

謝謝,它現在的工作 – Mark

+0

其實我錯誤閱讀了亞馬遜的一封電子郵件,這仍然不起作用! – Mark

2

我最近證實了我工作的公司成功的一個領域,它被設置爲我的域DNS如下(TXT記錄):

Amazon SES DNS

這可能是值得你讀Amazon's troubleshooting page如果你仍然有問題。

添加到我的回答:

我剛剛檢查了我的AWS控制檯,如果你打開了SES>域,然後單擊您的域名。向下滾動,然後單擊DKIM,我不得不確認一些有:

AWS DKIM

,並將其添加爲CNAME記錄如下:

DKIM DNS

有一件事人們忘記了這個過程是事實證明,亞馬遜要求您即使在驗證後仍然保留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記錄沒有正確設置。

+0

我剛剛回到這。是的,幾個月後,它仍然不工作:( – Mark

相關問題