1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

SES with App Runner で TimeoutError

Posted at

背景

App Runner が VPC に対応してからストレージへのスマートなアクセスが可能になりました。
VPCコネクターを PrivateSubnet 内に設定して RDS への接続に成功。
ついでに SES でメール送信もできるようにしておきたいということで早速 TimeoutErrorで躓くわけです。

課題

App Runner の送信向けのネットワーキングで、PrivateSubnet を設定しているので、当然外部への経路がありません。
そのため、メール送信先に接続できずにタイムアウトとなります。

さて、ここで先人の知恵をお借りします。

ASP.NET Core + Amazon SES な Web システムを App Runner でホスティングし、ネットワークパターンごとにメール送信してみた

ふむふむ。
NatGatewayは料金的にもやや心配な面もあるのでVPCエンドポイントを設定してみます。

しかし、ここで新たな問題に直面します。

hostname: 'email.ap-northeast-1.amazonaws.com',
...
Error: connect ETIMEDOUT xxx.xxx.xxx.xxx:443

VPCエンドポイントは間違い無く正しく設定したはずなのですが、接続できません。
他にも原因があるようです。

解決

調査を進めていくと、VPCエンドポイントのプライベートDNS名に目が行きました。

image.png

!!!
あなたは気が付いたでしょうか。
エラーログのFQDNとプライベートDNS名が異なることに。

はい、ここでやっと答えが分かりました。

VPCエンドポイントは、SMTPエンドポイント用しか無い!

というわけで、VPCエンドポイントを使いたければSMTPエンドポイント(SMTP認証)を使ってメール送信しましょう。
或いは、APIエンドポイントを使いたければ、NatGateway を使いましょう。

追加解説

SES でメール送信する方法は2つあります。

  1. SMTPエンドポイントを利用して送信
  2. APIエンドポイントを利用して送信

SMTPエンドポイントを利用する場合、SMTP認証での送信になるのでIAMユーザーのアクセスキーが必要になります。
その反面、APIエンドポイントは利用するリソースにロールを設定すれば送信できるのでセキュリティ的には圧倒的に後者の方が良いのです。

流出したときのダメージが大きいので、アクセスキーの発行は可能な限り避けたいところですね。

一言

email-smtp.ap-northeast-1.amazonaws.comemail.ap-northeast-1.amazonaws.com の違いに気が付けたのは良い勉強になりました。

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?