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 / 问题 / 386866
Accepted
Justin S
Justin S
Asked: 2012-05-08 14:17:25 +0800 CST2012-05-08 14:17:25 +0800 CST 2012-05-08 14:17:25 +0800 CST

负载平衡邮件网关

  • 772

我目前正在尝试找到一种方法来平衡我们的 4 个邮件网关(运行邮件清理器)。我能够启动 HAProxy 并使用 tcp 模式来毫无问题地进行负载平衡。唯一真正的问题是我的源 IP 始终是 HAProxy 服务器,所以我的一些邮件过滤器检查现在没有用,因为我无法检查邮件是否来自已知的错误中继。

他们是否有任何可用于处理此类情况的 FLOSS 软件?我知道 HAProxy 具有这种能力,如果我让邮件网关将它用作默认网关,并编译一些额外的模块并配置 iptables。如果我只是缺少一个更简单的解决方案,我只是不想开始这条路。

linux load-balancing smtp
  • 2 2 个回答
  • 2047 Views

2 个回答

  • Voted
  1. aseq
    2012-05-08T14:57:21+08:002012-05-08T14:57:21+08:00

    SMTP 以循环方式使用 DNS 内置了负载平衡。这对于大多数用途来说效果很好。如果这对您来说还不够,您将不得不创建自己的自定义设置,这不是一件容易的事。所以除非你真的需要它,否则我会坚持使用可用和广泛使用的东西。

    我假设您的电子邮件服务器 (MTA) 位于同一域(比如 example.org),在这种情况下,为每个单独的 MTA 创建一个具有相同优先级的 MX 记录。使用相同的优先级可确保以循环方式尝试每台服务器,否则总是先尝试优先级最高(编号较低)的服务器(在 MTA 未损坏的情况下,垃圾邮件发送者喜欢攻击优先级最低的服务器认为它可能是一个较低规格的“后备”服务器):

    example.org.    IN  MX  10  mx1.example.org.
    example.org.    IN  MX  10  mx2.example.org.
    example.org.    IN  MX  10  mx3.example.org.
    example.org.    IN  MX  10  mx4.example.org.
    

    当然要确保每个 mx* 都可以解析:

    example.org.    IN      A       192.168.2.1
    mx1     IN      A       192.168.2.2
    mx2     IN      A       192.168.2.3
    mx3     IN      A       192.168.2.4
    mx4     IN      A       192.168.2.5
    

    如果您还想使用 DNS 为您的用户发送电子邮件“负载平衡”MTA,您可以通过这种方式配置 DNS。让我们调用您的发件服务器 smtp.example.org 并告诉您的用户向其提交电子邮件。我将“负载平衡”放在引号中,因为这不会避免连接到 MTA 使用 MX 记录处理它的方式不正常的服务器。在这种情况下,用户必须重试一次或多次才能访问工作服务器。

    smtp    IN      A       192.168.2.2
    smtp    IN      A       192.168.2.3
    smtp    IN      A       192.168.2.4
    smtp    IN      A       192.168.2.5
    

    这是一个粗略的解决方案,因为根据用户的系统和设置,他们可能会继续尝试只攻击一个 IP。但至少它不是“对每个人都不利”,你总是可以将他们引导到工作服务器。此外,如果服务器永久关闭,您可以将其从 DNS 中删除,一旦缓存,就可以防止您的用户访问它。在这种情况下,haproxy 可能不是一个糟糕的解决方案。

    • 5
  2. Best Answer
    Michuelnik
    2012-05-08T22:06:51+08:002012-05-08T22:06:51+08:00

    我们只需使用Linux Virtual Server就可以做到这一点,多年来它一直是标准 linux 内核的一部分。

    它允许基于权重的负载平衡并且非常容易设置,我们正在做这样的事情:

    ipvsadm -A -t 192.168.0.3:25 -s wrr
    ipvsadm -a -t 192.168.0.3:25 -r 192.168.0.8:25 -g -w 100
    ipvsadm -a -t 192.168.0.3:25 -r 192.168.0.9:25 -g -w 100
    

    (其中 192.168.0.3 是您的“服务 IP”或“虚拟 IP”,192.168.0.8 和 192.168.0.9 是您的“真实服务器”)

    最重要的是要知道 - 操作方式。此设置使用“网关模式”,其中数据包的源和目标不会更改。但这有一些含义。必须在所有“真实服务器”上配置虚拟ip 。但这可能会导致 ARP 竞争条件,您应该通过设计避免这种情况:

    • 您的“真实服务器”位于单独 LAN 中的负载均衡器后面
    • 或者您将您的真实服务器配置为不回复虚拟地址的 ARP
    • 或者您将虚拟 IP 直接路由到您的负载均衡器,因此它不会被 ARP

    也许-m - 伪装模式更容易设置。

    并且 - 这里的另一个提示:您可能想要使用keepalived来设置 ipvsadm,监视您的邮件服务器的可达性,并且可能使用 VRRP 为负载均衡器本身提供冗余。

    我们正在使用 ipvs 来处理 15k CPS DNS 负载平衡。

    (*) 至少在 debian 中是这样称呼的,但是搜索 ipvs 应该很容易

    • 2

相关问题

  • 多操作系统环境的首选电子邮件客户端

  • 你最喜欢的 Linux 发行版是什么?[关闭]

  • 更改 PHP 的默认配置设置?

  • 保护新的 Ubuntu 服务器 [关闭]

  • (软)Ubuntu 7.10 上的 RAID 6,我应该迁移到 8.10 吗?

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