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 / 问题 / 101513
Accepted
SyRenity
SyRenity
Asked: 2010-01-12 05:09:53 +0800 CST2010-01-12 05:09:53 +0800 CST 2010-01-12 05:09:53 +0800 CST

心跳与 UCarp

  • 772

谁能解释 IP 故障转移场景中 Heartbeat 和 UCarp 之间的主要区别是什么?

他们似乎都提供了这个功能,也许 UCarp 设置起来更简单?

谢谢。

high-availability heartbeat linux-ha
  • 1 1 个回答
  • 6905 Views

1 个回答

  • Voted
  1. Best Answer
    pQd
    2010-01-12T05:32:11+08:002010-01-12T05:32:11+08:00

    我假设您对简单的主动-被动设置感兴趣。

    ucarp 和 heartbeat 在这种设置中做的事情几乎相同。本质上 - 当机器被选为主/热备用时,它们运行提供的脚本。

    heartbeat 可能看起来要复杂得多[因为它可以帮助您自动挂载 drdb,重新启动多个服务等],但最后 - 您可以编写所有这些脚本并让 ucarp 调用它]。

    就个人而言 - 我用单一资源运行心跳 - 这是执行以下操作的脚本:

    • [un]绑定合适的IP地址
    • 运行几个 arp 广播
    • 启动[停止]所需的服务

    我非常简单的设置 [debian lenny 下的 heartbeat 2.1.3-6]:我有两台服务器:

    • ser0 [首选活动节点],在 eth0 永久分配 10.0.0.2/24
    • ser0b [hot-standby node waiting to replace master] 在 eth0 永久分配 10.0.0.3/24

    'floating ip' - 分配给活动节点的 10.0.1.1/24 分配给 eth1

    在这种情况下,获得高可用性的服务是 apache。我分别同步从 ser0 到 ser0b 的 apache 配置和内容。

    以下文件在两台机器上都是相同的,但有一个明显的例外:

    /etc/ha.d/authkeys:

    auth 1
    1 md5 somethingrandom
    

    /etc/ha.d/haresources

    ser0 ha.sh
    

    /etc/ha.d/ha.cf

    keepalive 2
    deadtime 10
    udpport        694 
    ; below - address permanently assigned to the peer node . this is for master:
    ucast eth1 10.0.0.3
    ; and on slave i have 
    ; ucast eth1 10.0.0.2
    udp     eth0
    logfacility     local0
    auto_failback on
    
    node    ser0
    node    ser0b
    

    /etc/init.d/ha.cf [它也可以在 /etc/ha.d/resources.d/ha.cf ]

    #!/bin/bash
    case "$1" in
      start)
            ip link set dev eth1 up
            # bind 'floating' ip to the interface
            ip a a 10.0.1.1/24 dev eth1
            # you might want to add some route-changes here if needed
            /usr/lib/heartbeat/send_arp -r 10 eth1 10.0.0.1 auto 10.0.0.255 255.255.255.0
            # to make sure apache reloads it's config when machine becomes master
            /etc/init.d/apache2 restart
      ;;
    
      stop)
            # we are no longer active, un-bind 'floating' ip from the interface
            ip a d 10.0.1.1/24 dev eth1
            # you could stop it as well or just skip this step
            /etc/init.d/apache2 restart
      ;;
    esac
    exit 0
    
    • 4

相关问题

  • LVS 集群帮助

  • 适用于 Linux 的良好故障转移/高可用性解决方案?[关闭]

  • 由于 MySQL DRBD Heartbeat 故障转移脚本导致的数据丢失

  • SQL Server - 集群与镜像的高可用性?

  • SQL Server 群集选项

Sidebar

Stats

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

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

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +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