我们有两个邮件服务器(“dubone”和“dubdeuce”),其中一个负责所有工作,另一个则处于空闲状态。我们希望有一个设置,如果 dubone 繁忙或宕机,dubdeuce 可以像 dubone 一样接受/拒绝/过滤电子邮件。
然后,一旦 dubone 再次可用,dubdeuce 会将其存储的所有电子邮件推送到 dubone,以便所有电子邮件都集中在一个地方。
我们使用由 MySQL 支持的 Exim4 和 Dovecot,并且可以通过 RoundCube 访问。两台机器都运行 Ubuntu Linux。
我如何同步两台机器之间的数据库,以便 dubdeuce 始终是最新的(它需要保持最新才能正确完成其工作),然后我如何指示 dubdeuce 将其所有累积的消息推送到 dubone?
答案1
您在这里询问的问题有三个组成部分:数据库复制、邮件冗余和用户访问。
数据库复制很简单,MySQL 文档。
邮件复制通常与确保您的 MX 记录设置正确一样简单。如果 dubdeuce 不是主 MX,它会在主 MX 再次可用时将邮件转发到主 MX。
但是,您没有明确说明,但您包含 roundcube 意味着您希望第二个系统在 MUA 方面完全可操作 - 您希望用户能够阅读电子邮件。如果不是这样 - 您很乐意让 roundcube 处于离线状态直到 dubone 恢复 - 那么上述组件将为您完成这项工作。
再说一遍:如果您想要的只是一个简单的系统,该系统将存储并转发电子邮件,直到主服务器恢复,那么您只需要为 mysql 进行数据库复制并使用辅助 MX。此系统应始终处于活动状态,而不仅仅是在需要时启动。
如果您想要一个完全冗余的系统,其中 roundcube 始终可用,那么您需要的是两个系统之间的共享邮件池。没有真正的方法可以将 dubduece 配置为主要 MX,并让用户能够从中读取邮件,并让它明智地将电子邮件转发到 dubone。
因此,您需要一个共享邮件池。这可以是充当文件服务器的第三个系统,为两个主要主机提供邮件池,但是由于锁定问题,长期以来建议不要使用 NFS 作为邮件池。
可以使用DRBD在两个节点之间,处于主动/备份模式 - 当一个节点发生故障时,可以使用心跳将另一个节点切换为活动节点。当第一个节点重新上线时,您将需要一个心跳过程来将所有内容切换回来。您仍然需要弄清楚如何复制数据库 - 您现在可能需要一个多主服务器设置。
最后,您可以使用 DRBD 做同样的事情,但在其上使用集群感知文件系统,并让两个节点始终处于活动状态。不过这有点复杂。您也可以在节点之间对整个邮件系统进行 DRBD。并且有很多方法可以扩展 - 更高级的解决方案涉及 SAN 和 VM 堆栈,如 Citrix Xenserver 或 VMware。
就我个人而言,我会坚持使用主动/被动 DRBD 邮件池,无论是多主控 mysql 还是 DRBD 主动/被动支持的 mysql,并使用 heartbeat 来启用故障转移时的活动服务。另一种方法是使用 Xen 或 KVM 或任何你喜欢的虚拟机将整个邮件服务器放入虚拟机中,将虚拟机备份到 DRBD 系统上,并让 heartbeat 故障转移 DRBD 并在发生故障时在第二个节点上启动虚拟机。在这个例子中,你实际上只有“一个”邮件服务器,它只是在你的节点之间浮动。缺点是你必须等待它在故障转移时启动,这可能需要一段时间。
附注:无论您如何操作,请确保两个系统上的垃圾邮件/病毒/恶意软件/等扫描配置相同。