sendmagicってなんだっけ?

 sendmagicってなんだっけ?

smtpの基礎とsendmagic、及び2014春にあったsendmagic配信遅延の原因について。

E60aa4f80303f3f386898546ddb3686a?s=128

Livesense Inc.

April 23, 2014
Tweet

Transcript

  1. confluenceを使いやすく

  2. と予告したんですが。 今回、confluence用に作ってる機能拡張の紹介を しようと思ったんですが、微妙に進捗が悪いのと別 件で面白い話が出来たんで、急遽そっちの話にし ます。

  3. sendmagicって なんだっけ? sendmagicの仕組みと性能について

  4. sendmagicってなんだっけ? sendmagicが何をしてくれている物か僕は実は ちゃんとは把握してませんでした。 朧げながらこういうものかな?なイメージはありまし たが。

  5. 最近sendmagicでの送信が遅配されるという件で sendmagicを調査していたので、その情報を共有 しようと思います。

  6. 非エンジニアの方にもわかるように説明するつもり です。 少し説明しやすいように、所々簡略化する為のウ ソを交えます。

  7. そもそもメール配信のしくみ A社内同士の場合(微妙に嘘入ってます) thunderbirdとか thunderbirdとか メール サーバー 外行き メール サーバー α部署用

    メール サーバー β部署用 A社 外部
  8. そもそもメール配信のしくみ 例としてA社からB社へ送った場合(微妙に嘘入ってます) thunderbirdとか thunderbirdとか メール サーバー 外行き メール サーバー α部署用

    メール サーバー β部署用 メール サーバー 外から受 付用 メール サーバー 受信用 thunderbirdとか A社 B社
  9. このように、遠く(インターネット的)にメールを送る 時には、何段もメールサーバーがバケツリレーをし て送ります。

  10. また、本質的には、Thunderbirdもメールサーバー と変わりません。 みんなが入力したメールを他のメールサーバーに リレーしています。そしてバケツリレーの方法は サーバー間の方法と全く同じ方法でやってます。

  11. 非エンジニアさんへ 良くエンジニアがメールの障害があった時に ヘッダも込みで全部頂戴 というのは、この中継している情報が欲しいからで す。

  12. 到達性とリアルタイム性 最近では巷のサーバースペックやネットワークの 信頼性も上ってるので、メール到達性が向上して いますが、仕組み的には100%の到達性が保証出 来ない仕組みです。 また、バケツリレーをしているので、どんなにがん ばっても多少の遅配は発生します。

  13. sendmagicとは、メール配信を • 出来るだけ確実 • 高速 に行なう為のミドルウェアです。 他、配信時刻制御とかログ解析しやすいとかX-SM-IDで色々出来るとか、色々ある けど、今回は割愛。 sendmagicってなんだっけ?

  14. sendmagicの位置付け sendmagicも位置付けとしては中継するサーバー の一種です。 thunderbirdに相当するのが、エンジニアが作って いるアプリになります。

  15. 出来るだけ確実に? 今メールはspamが酷くて、その対処に各プロバイ ダー等は色々な施策を行なっています。

  16. spf 一つには、dns(URL的な物(host名)からipアドレス (システムが理解出来る住所)への変換)の仕組み を使ったspfがあります。 spfはこのメールサーバーから送信されるメールは 基本spamじゃないよ。という名乗りです。 ここらへんからエンジニア職じゃない人にはわかりずらくなるかもしれませんが、ご容 赦の程を。

  17. spf $ dig jobtalk.jp txt ….. ;; ANSWER SECTION: jobtalk.jp.

    3600 IN TXT "v=spf1 include:spf.livesense.co.jp include:support.zendesk.com include:smtp. zendesk.com ~all" ….. $ dig spf.livesense.co.jp txt ….. ;; ANSWER SECTION: spf.livesense.co.jp. 906 IN TXT "v=spf1 ip4:202.32.221.247 ip4:202.32.221.248 ip4:180.214.38.128/25 ip4: 112.140.41.128/25 ip4:180.214.49.190/30 ip4:180.214.49.194/30 ip4:203.223.25.12/32 ip4:203.223.25.13/32 include: aspmx.googlemail.com ~all" ….. という感じで、jobtalk.jpからのメールはここのipからメール打つんで、それはspamじゃないよ宣言。
  18. spfで防げる範囲 あくまでも、セキュリティの甘いメールサーバーや、 ウィルス感染したPCを利用したspamが防げるだ け。 spam業者 (jobtalk以 外のfrom) gmail.com jobtalk.jp

  19. 実は、特定ipからメールを送り過ぎると、それも spam判定される可能性がある。 jobtalk.jp gmail.com a@gmail.com b@gmail.com c@gmail.com 違うメールアドレスでも、ドメインが同じだと同じサーバーに繋ぎに行きます。(微妙にウソ) d@gmail.com 送信多すぎ。ぁゃιぃ

  20. そこでsendmagicの出番 送信元のipアドレスをsendmagicが複数持ってい て、それを並列で使う事により、メール送り過ぎ判 定を少しでも避ける。 jobtalk.jp gmail.com sendmagic sendmagic a@gmail.com /

    b@gmail.com c@gmail.com / d@gmail.com
  21. 確実に? その2 指定ドメインに対する並列配送数の設定が簡単に 可能。 これが多すぎると接続のペナルティを課せられる 可能性がある。 ちなみに普通のsmtp server(postfixとか)にもdomain毎の並列配送数の設定が可 能だが、設定が結構ややこしい。

  22. 例えば、現在の設定だと、 • X-SM-IDにcronが入ってないgmailは12並列 (会員登録等のリアルタイム処理用) • cronが入っている場合は6並列(メルマガ配信等 用) など。

  23. 高速に。 先程紹介した並列処理による高速化もだし、単体 でのスループットも速い(らしい。ここはちょっと未検 証。他のミドルの基礎値を知らない為)。

  24. 実際メールを手で送ってみよう。 $ dig gmail.com mx | grep -E '^gmail.com' |

    sort -nk 5 | head -n 1 $ telnet hoge 25 HELO jobtalk.jp MAIL FROM: <info@jobtalk.jp> RCPT TO: <vikke.bsd@gmail.com> DATA From: info@jobtalk.jp Subject: test this is test. . QUIT gmailの場合、応答 が遅い。
  25. 実際のスループット ログをdbに入れて集計してみました。 yahoo: 15000通 / 10分 gmail: 2100通 / 10分

  26. ( ゚д゚) ・・・   (つд⊂)ゴシゴシ   (;゚д゚) ・・・   (つд⊂)ゴシゴシゴシ  _,

    ._ (;゚ Д゚) …!? yahooの1 / 7以下 …..
  27. 今回メール送信が詰まった原因 メール送信の送信先指定にgmailが異様に時間が かかっている。 その為、gmailだけ詰まっている。実際sendmagic 自体にコマンドで問い合わせてもすごく溜ってい た。 他、sendmagicのパラメータにもチューニングの余 地あり。

  28. ちなみに他の数値として 以下直近(3/28 金曜日21:00迄)10日間の集計値 総配信トライ数 8129538 内、リトライ回数 484457 (5.9%) 総リトライを断念して失敗した数 490832(なお送信失敗が確定したメールアドレスは

    ブロックリストに登録され今後送信されなくなる) リアルタイム送信 / バッチ送信比率 • gmail: リアルタイム: 80000 / バッチ: 1700000 とバッチが20倍程 • yahoo: リアルタイム:73000 / バッチ: 2443000 とバッチが33倍程
  29. 現在の状況 • 元々sendmagicが落ちたり、ipが拒否された時用に active/standby構成になっていた。この内、standbyを jobtalkのメルマガ(cron)配信用に利用。 • そのjobtalkのメルマガ配信に使っているsendmagicの各種 パラメータやフィルターをチューニング中。 • 今、active/standby双方を使っているが、パラメータチュー

    ニングで1台に寄せられるのか無理なのか、無理ならどうす るのかを調査中。