送信者を実装する言語よりも大量の電子メールがあります。リッチによって提案されたライブラリに関する限り、SMTPリレーを使用してメールをキューに入れて調整することを検討します。
私が会社の大量メーラーを書いたときに発見したように、バルクメーラーが直面する主な問題は、メールをエーテルにパントアウトできる速度と、グレーリストに登録されたメールの再試行をどのように管理するかなどです。
したがって、第1に、メールアウトジョブを実行できる優れた堅牢なSMTPサーバーが必要です。また、サービスを抑制して監視する方法も必要になります。IISを実行し、適度に大きなパイプに接続されている標準のWindows Serverでは、15分ごとに5kのメールをクリアできます。あなたが48時間でそれらすべてを実装することを探しているなら、あなたはプッシュされるでしょう。
実際のところ、データをプッシュできる速度には厳しい制限があり、ISPなどによって課せられる人為的な制限もあります。これにより、カタツムリのペースでジョブを実行したくない場合は、スロットルや正しいDNSレコードなどが絶対に不可欠になります。10kのメールをドアから押し出すことができる最小時間(そしてメールのサイズは約50kbなので、スループットについてさらに詳しく知ることができます)は30分で、最上位のキットと膨大な数の接続があります。私たちをバックアップする配水管。
私たちの会社の初期の頃、彼らが私たちのローカルブロードバンドからものを郵送していたとき、7000通のメールを送るのに約12-14時間かかりました。したがって、物理的なリソースが非常に重要であることを理解する必要があります。
また、必然的に、最初のタイムアウトでは配信されない10kあたり最低約50通のメールが送信されることになります。そしてそれらの約10はこれまでどこにも行きません。再試行キューにこれらのメールが存在すると、メールのさらなるバッチの配信に多少の抵抗効果が生じる可能性があります。これは最小限ですが重要です。
また、1万通のメールファイルをサーバーにぶつけて、それについて完全に満足することを期待することはできません。実験の結果、3分ごとに1,000通のメールを滴下すると、送信するキューの比率が最適になることがわかりました。マイレージはハードウェアによって異なります。
率直に言って、ソフトウェアライブラリの選択は、この段階での心配の中で最も少ないものです。