ScArcher2 Asked: 2009-05-01 05:43:23 +0800 CST2009-05-01 05:43:23 +0800 CST 2009-05-01 05:43:23 +0800 CST 为手动故障转移设置 linux Web 服务器的最有效方法是什么 772 我目前使用 apache、mysql 和 ssh 管理一个运行 ubuntu linux 的小型 Web 服务器。我正在使用 rsync 将它备份到另一台服务器,但我正在将它备份到 /backup 目录。 我想设置它,如果第一台服务器出现故障,我可以更改第二台服务器的 ip 并准备好所有用户、文件、数据库等。 有人对解决此问题的最简单/最佳方法有任何建议吗? 注意事项 用户 数据库 阿帕奇配置 文件 确保两个盒子上都安装了相同的软件。(可能需要预先执行此操作) linux ubuntu failover 4 个回答 Voted Mark Regensberg 2009-05-02T00:01:03+08:002009-05-02T00:01:03+08:00 对于基于文件的服务(Web 服务器等),rsync 可以有效地使第二台服务器保持最新——(用户、配置等)——当涉及到数据库时,事情会变得有点复杂(我使用过 MySQL 和从属服务器为此,它非常有效,我还在一些 HA/备用配置中使用了 PostgreSQL,但它更笨拙) 这与一些 IP 盗窃(将故障机器的 IP 分配给备份机器接口的快速脚本)相结合,可以进行相对简单的设置,但允许快速恢复。 只需要考虑一件事——提防故障回复。将服务移至备份机器是一回事,一旦您纠正了故障,将它们移回来可能会很麻烦,请密切注意数据库。 如果您决定使其更加自动化,LinuxHA 是一种(有点重量级的)方法 http://www.linux-ha.org/ Brent 2009-05-02T07:16:10+08:002009-05-02T07:16:10+08:00 您可以使用rsync或drbd使备份服务器保持同步,或通过nfs从第三台服务器装载数据。如果您想保持简单,我将备份到备份服务器上与源服务器相同的目录位置。 heartbeat2是管理 IP 地址的一个很好的解决方案,并提供了自动或手动故障转移的工具 - 并考虑了 arp 缓存刷新和其他我没有想到的事情。 Hamish Downer 2009-05-01T06:16:53+08:002009-05-01T06:16:53+08:00 虚拟化可以在这里提供帮助。您可以将 2 台服务器作为主机服务器运行,同时配备一台准备就绪的虚拟服务器。实时服务器运行虚拟服务器,而备份服务器“关闭”虚拟服务器,但仍可以访问该服务器的文件系统。 然后,您可以定期从实时虚拟服务器到备份虚拟服务器进行 rsync。如果实时服务器出现故障,您只需要启动备份虚拟服务器。 细节取决于你使用的虚拟化软件(我之前用 linux-vserver 做过),但一些重要的点是: 您将需要排除一些设置 - 特别是 IP 地址。 在一切正常时测试您的设置 - 您需要知道它是否有效 为 www1.mysite.com 和 www2.mysite.com 设置了 DNS,其中 www.mysite.com 是 www1 和 www2 的循环 您甚至可以研究某种心跳服务来自动启动备份服务器,但这可能过于复杂,除非停机时间真的很昂贵。 Zan Lynx 2009-09-17T06:33:48+08:002009-09-17T06:33:48+08:00 我相信heartbeat会为你做这件事,但如果你不使用它,我建议你手动为web服务器设置一个虚拟IP。 每个 Web 服务器都有自己的真实 IP 和虚拟 IP。虚拟 IP 仅在机器是活动 Web 服务器时才分配给它。 这种设置意味着 ssh、rsync 和所有其他工具可以继续在真实 IP 上运行,而不会被不断变化的 IP 地址所迷惑。
对于基于文件的服务(Web 服务器等),rsync 可以有效地使第二台服务器保持最新——(用户、配置等)——当涉及到数据库时,事情会变得有点复杂(我使用过 MySQL 和从属服务器为此,它非常有效,我还在一些 HA/备用配置中使用了 PostgreSQL,但它更笨拙)
这与一些 IP 盗窃(将故障机器的 IP 分配给备份机器接口的快速脚本)相结合,可以进行相对简单的设置,但允许快速恢复。
只需要考虑一件事——提防故障回复。将服务移至备份机器是一回事,一旦您纠正了故障,将它们移回来可能会很麻烦,请密切注意数据库。
如果您决定使其更加自动化,LinuxHA 是一种(有点重量级的)方法
http://www.linux-ha.org/
您可以使用rsync或drbd使备份服务器保持同步,或通过nfs从第三台服务器装载数据。如果您想保持简单,我将备份到备份服务器上与源服务器相同的目录位置。
heartbeat2是管理 IP 地址的一个很好的解决方案,并提供了自动或手动故障转移的工具 - 并考虑了 arp 缓存刷新和其他我没有想到的事情。
虚拟化可以在这里提供帮助。您可以将 2 台服务器作为主机服务器运行,同时配备一台准备就绪的虚拟服务器。实时服务器运行虚拟服务器,而备份服务器“关闭”虚拟服务器,但仍可以访问该服务器的文件系统。
然后,您可以定期从实时虚拟服务器到备份虚拟服务器进行 rsync。如果实时服务器出现故障,您只需要启动备份虚拟服务器。
细节取决于你使用的虚拟化软件(我之前用 linux-vserver 做过),但一些重要的点是:
我相信heartbeat会为你做这件事,但如果你不使用它,我建议你手动为web服务器设置一个虚拟IP。
每个 Web 服务器都有自己的真实 IP 和虚拟 IP。虚拟 IP 仅在机器是活动 Web 服务器时才分配给它。
这种设置意味着 ssh、rsync 和所有其他工具可以继续在真实 IP 上运行,而不会被不断变化的 IP 地址所迷惑。