AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1177963
Accepted
TattooedGun
TattooedGun
Asked: 2025-03-31 08:01:05 +0800 CST2025-03-31 08:01:05 +0800 CST 2025-03-31 08:01:05 +0800 CST

从同一台 Windows Server 2022 服务器上的多个 IP 地址发送邮件

  • 772

在使用 Windows Server 2022 的 Web 托管专用服务器上,五年来,我们一直通过 IIS 6.0 向平台上拥有 1 万名用户的客户每日发送邮件,从未出现任何问题。他们最近将策略更新为“外部”邮件(提供的产品仅供其内部使用,我们被视为外部公司),这意味着由于我们仅从单个 IP 地址发送邮件,因此我们的发送速率受到限制——导致每天(向特定收件人)发送 1 万封电子邮件最多需要 8 个小时,这对于我们希望及时向用户发送关键更新的情况来说并不理想(在此次策略变更之前的 5 年里,我们已经习惯了这种发送方式)。

他们的 IT 安全团队建议我们增加发送邮件的 IP 地址数量。

为了增加邮件的 IP 覆盖范围,我们为机器分配了一个额外的 IP 地址,在 IIS 6.0 中设置了一个额外的虚拟服务器,分配了 IP 地址后才发现机器的主 IP 将自己签名为所有邮件的来源,而额外的 IP 地址纯粹用于入站邮件,而不是我们尝试发送的出站邮件。

根据网上一些可疑的建议,我安装了 hMailServer,幻想着我可以使用它来创建多个服务器,并让它使用设置中的 IP 地址对出站邮件进行签名,但遗憾的是,这只是在源后添加了一个额外的跳转,似乎并不能解决问题。

我正在阅读有关使用 DNS Round-Robin 进行邮件传递、使用 HAProxy 作为负载均衡器等内容,但我根本不知道(最佳?)前进的方向。

出于安全考虑,我们希望将所有邮件保留在“内部”服务器,而不是使用第三方 SMTP 中继提供商。- 在 Windows 架构下,是否有任何方法可以解决此问题,并能够以相当均匀的方式跨多个 IP 地址发送多封邮件?我们是否需要研究基于 Linux 的虚拟机解决方案?

您是否解决过类似的问题?

smtp
  • 2 2 个回答
  • 78 Views

2 个回答

  • Voted
  1. Greg Askew
    2025-03-31T17:15:08+08:002025-03-31T17:15:08+08:00

    选项 A:将负载分散到不同主机上的多个传出 SMTP IP 地址。

    选项 B:收件人授予发送 IP 地址例外。

    • 2
  2. Best Answer
    Nikita Kipriyanov
    2025-03-31T18:12:01+08:002025-03-31T18:12:01+08:00

    我同意评论者的观点,既然这个问题并非由真正的技术限制导致,而是由某些人的不明智行为造成的,那么为了解决这个问题,最好撤销该操作。就您而言,这相当于政策豁免。

    如果这是政治游戏,那么你们的政客就做错了。有时,做决策的人根本不知道他们的决策是错误的,或者他们的想法之前被尝试过,但最终被证明不是最优的。作为一名专业的IT专家,你的职责就是让他们了解你专业领域中的最佳和不良做法。例如,额外的IP地址需要额外付费,因此提高你为该客户提供的服务费是合理的,这样他们就可以承担你由于他们固执的策略管理而产生的额外费用。但他们完全可以通过友好地配置策略来避免这种情况。管理层的人通常非常了解这种“金钱论”。

    如果您已准备好设置基于 Postfix 的智能主机(例如 Linux 或某些 Unix 系统,因为 Windows 上没有 Postfix),您可以使用其randmap功能。使用方法如下:对于主 Postfix 实例,请在以下位置设置main.cf:

    sender_dependent_default_transport_maps = randmap:{relay1,relay2,relay3}
    smtp_connection_cache_on_demand=no
    

    这些relayX名称是 SMTP 客户端(“发送方”)服务,定义master.cf如下:

    relay1     unix  -       -       n       -       -       smtp
      -o smtp_bind_address=192.0.2.1
      -o smtp_helo_name=relay1.example.com
      -o syslog_name=relay1
    relay2     unix  -       -       n       -       -       smtp
      -o smtp_bind_address=192.0.2.2
      -o smtp_helo_name=relay2.example.com
      -o syslog_name=relay2
    relay3     unix  -       -       n       -       -       smtp
      -o smtp_bind_address=192.0.2.3
      -o smtp_helo_name=relay3.example.com
      -o syslog_name=relay3
    

    根据你的喜好添加更多。它会随机选择一个中继。然后,你可以将此 Postfix 系统设置为你原始邮件程序的智能主机。

    值得注意的是,在 DNS 中,的 PTR 记录192.0.2.1必须是,最好relay1.example.com是relay1.example.com包含单个 IP 地址的 A 记录192.0.2.1,其他所有地址也应如此。此外,如果这些地址都属于同一个 /30 地址块,则必须将它们全部发布到“发件人”域的 SPF 记录中,如下所示:ip4:192.0.2.1, ip4:192.0.2.2 ip4:192.0.2.3或a:relay1.example.com a:relay2.example.com a:relay3.example.com,或任何简写形式,例如:ip4:192.0.2.0/30。

    如果您仅打算使用此方法来解决速率限制问题,则无需通过 MX 查找来解析这些地址。事实上,当您开始像这样扩展系统时,合理的做法是设置一组专用地址仅用于接收邮件,仅在 MX 中发布;以及设置另一组专用地址(这组地址仅用于发送邮件,仅在 SPF 中发布)。

    • 1

相关问题

  • Postfix 或 exim:自动/程序化和转发电子邮件设置

  • 如何将 SMTP 直接从 IIS 6.0 服务器中继到 Exchange 2003 服务器

  • 使用 telnet 或 netcat 发送带有附件的电子邮件

  • 我应该使用什么策略在 linux 上安装 smtp 服务器?用于多线程服务

  • 适用于 Linux 的 SMTP 服务器,配置简单

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve