heartbeat 监听在udp的694的端口

 

LRM:本地资源管理器

CRM:资源管理器

RA:资源代理(脚本)

heartbeat legacy : heartbeat 传统类型的资源代理,通常位于/etc/ha.d/haresources.d/目录下;

 
 

LSB:/etc/rc.d/init.d/*{start|stop|status|restart} 目录下的脚本;

        
 

 

 

具体实现:

[root@stu21 ~]# lftp 172.16.0.1

lftp 172.16.0.1:~> cd pub/Sources/6.x86_64

lftp 172.16.0.1:/pub/Sources/6.x86_64> mirror heartbeat2/

Total: 1 directory, 7 files, 0 symlinks

New: 7 files, 0 symlinks

5829264 bytes transferred

lftp 172.16.0.1:/pub/Sources/6.x86_64>

 

lftp 172.16.0.1:/pub/Sources/6.x86_64> bye

[root@stu21 ~]# ls

anaconda-ks.cfg heartbeat2 install.log lamp_source nginx-1.4.7.tar.gz nginx-1.6.2.tar.gz

dir.sh ifcfg-eth6 install.log.syslog nginx nginx-1.6.2

[root@stu21 ~]# cd heartbeat2/

[root@stu21 heartbeat2]#

[root@stu21 heartbeat2]# ls

heartbeat-2.1.4-12.el6.x86_64.rpm heartbeat-ldirectord-2.1.4-12.el6.x86_64.rpm

heartbeat-debuginfo-2.1.4-12.el6.x86_64.rpm heartbeat-pils-2.1.4-12.el6.x86_64.rpm

heartbeat-devel-2.1.4-12.el6.x86_64.rpm heartbeat-stonith-2.1.4-12.el6.x86_64.rpm

heartbeat-gui-2.1.4-12.el6.x86_64.rpm

 

安装方法:

            1、# yum install net-snmp-libs libnet PyXML perl-Time-Date

            2、# rpm -ivh heartbeat-2.1.4-12.el6.x86_64.rpm heartbeat-stonith-2.1.4-12.el6.x86_64.rpm heartbeat-pils-2.1.4-12.el6.x86_64.rpm

 

 

同步时间

(两个节点)

节点一(172.16.21.6)

[root@stu21 heartbeat2]# ntpdate 172.16.0.1

31 Dec 20:59:25 ntpdate[6950]: adjust time server 172.16.0.1 offset 0.379319 sec

[root@stu21 heartbeat2]#

 

最好几分钟同步一下

[root@stu21 heartbeat2]# crontab -e

no crontab for root - using an empty one

 

*/3 * * * * /usr/sbin/ntpdate 172.16.0.1 &> /dev/null

 

~

~

 

 

节点二:(172.16.21.10)

 

[root@stu21 heartbeat2]# ntpdate 172.16.0.1

31 Dec 21:00:50 ntpdate[4737]: adjust time server 172.16.0.1 offset 0.380532 sec

[root@stu21 heartbeat2]#

最好每个几分钟同步一下

 

[root@stu21 heartbeat2]# crontab -e

no crontab for root - using an empty one

 

*/3 * * * * /usr/sbin/ntpdate 172.16.0.1 &> /dev/null

 

~

~

在节点一上生成密钥,使得两节点间检测心跳信息无须密码

[root@stu21 .ssh]# ssh-keygen -P ''

Generating public/private rsa key pair.

Enter file in which to save the key (/root/.ssh/id_rsa):

Your identification has been saved in /root/.ssh/id_rsa.

Your public key has been saved in /root/.ssh/id_rsa.pub.

The key fingerprint is:

75:cc:d5:7e:f8:ae:d6:c7:7b:36:45:f6:22:a8:06:dc root@node1.stu21.com

The key's randomart image is:

+--[ RSA 2048]----+

| .. |

| o . .|

| . + o |

| . . . =|

| . .S . +o|

| o E . . . +|

| . . . =.|

| o ..B|

| . ..+=|

+-----------------+

[root@stu21 .ssh]#

在 节点1 的 /etc/hosts 下增加 " uname -n " 所显示两个节点的内容

172.16.21.6 node1.stu21.com node1(别名)

172.16.21.10 node2.stu21.com node2(别名)

 

[root@stu21 ~]# ssh-copy-id -i .ssh/id_rsa.pub root@node2

 

The authenticity of host 'node2 (172.16.21.10)' can't be established.

RSA key fingerprint is 6a:5a:71:de:61:ca:29:01:c2:7d:8d:6f:06:27:2b:b2.

Are you sure you want to continue connecting (yes/no)? yes

Warning: Permanently added 'node2' (RSA) to the list of known hosts.

root@node2's password:

Now try logging into the machine, with "ssh 'root@node2'", and check in:

 

.ssh/authorized_keys

 

to make sure we haven't added extra keys that you weren't expecting.

 

[root@stu21 ~]# cd .ssh/

[root@stu21 .ssh]# ls

authorized_keys id_rsa id_rsa.pub known_hosts

 

[root@stu21 .ssh]# ssh node2 'date';date

Wed Dec 31 21:38:29 CST 2014

Wed Dec 31 21:38:29 CST 2014

[root@stu21 .ssh]#

 

 

[root@stu21 ~]# scp /etc/hosts node2:/etc/hosts

hosts 100% 358 0.4KB/s 00:00

[root@stu21 ~]#

 

 

在节点2 的终端上生成密钥一份给 节点2的机子上

 

[root@stu21 ~]# ssh-keygen -t rsa -P ''

Generating public/private rsa key pair.

Enter file in which to save the key (/root/.ssh/id_rsa):

Your identification has been saved in /root/.ssh/id_rsa.

Your public key has been saved in /root/.ssh/id_rsa.pub.

The key fingerprint is:

fe:fe:67:a7:c2:da:23:a9:91:28:05:4b:06:ea:87:84 root@node2.stu21.com

The key's randomart image is:

+--[ RSA 2048]----+

| . |

|.. . |

|E. + |

|o .o o |

| o .. . S |

| . . o . |

| . . + o |

| . oo.+ o .|

| .o++o=.o |

+-----------------+

[root@stu21 ~]#

 

 

[root@stu21 ~]# ssh-copy-id -i .ssh/id_rsa.pub root@node1

 

The authenticity of host 'node1 (172.16.21.6)' can't be established.

RSA key fingerprint is 6a:5a:71:de:61:ca:29:01:c2:7d:8d:6f:06:27:2b:b2.

Are you sure you want to continue connecting (yes/no)? yes

Warning: Permanently added 'node1,172.16.21.6' (RSA) to the list of known hosts.

root@node1's password:

Permission denied, please try again.

root@node1's password:

Now try logging into the machine, with "ssh 'root@node1'", and check in:

 

.ssh/authorized_keys

 

to make sure we haven't added extra keys that you weren't expecting.

 

验证下是否能检测对方时间

[root@stu21 ~]# ssh node1 'date' ; date

Wed Dec 31 21:50:55 CST 2014

Wed Dec 31 21:50:55 CST 2014

[root@stu21 ~]#

 

前期准备已将完成,接下来就是配置la

分别在两个节点机子上检查

[root@stu21 ~]# rpm -ql heartbeat

 

 

 

 

[root@stu21 ~]# cd /usr/share/doc/heartbeat-2.1.4/

[root@stu21 heartbeat-2.1.4]# ls

apphbd.cf COPYING.LGPL GettingStarted.txt hb_report.html README startstop

authkeys DirectoryMap.txt ha.cf hb_report.txt Requirements.html

AUTHORS faqntips.html HardwareGuide.html heartbeat_api.html Requirements.txt

ChangeLog faqntips.txt HardwareGuide.txt heartbeat_api.txt rsync.html

COPYING GettingStarted.html haresources logd.cf rsync.txt

[root@stu21 heartbeat-2.1.4]# cp -p authkeys haresources ha.cf /etc/ha.d/

[root@stu21 heartbeat-2.1.4]#

 

[root@stu21 heartbeat-2.1.4]# cd /etc/ha.d/

[root@stu21 ha.d]#

[root@stu21 ha.d]# ll

total 48

-rw-r--r-- 1 root root 645 Sep 10 2013 authkeys

-rw-r--r-- 1 root root 10539 Sep 10 2013 ha.cf

-rwxr-xr-x 1 root root 745 Sep 10 2013 harc

-rw-r--r-- 1 root root 5905 Sep 10 2013 haresources

drwxr-xr-x 2 root root 4096 Dec 31 20:43 rc.d

-rw-r--r-- 1 root root 692 Sep 10 2013 README.config

drwxr-xr-x 2 root root 4096 Dec 31 20:43 resource.d

-rw-r--r-- 1 root root 7864 Sep 10 2013 shellfuncs

[root@stu21 ha.d]#

 

改下加深颜色的文件权限必须为 600或是400

[root@stu21 ha.d]# chmod 600 authkeys

[root@stu21 ha.d]# ll

total 48

-rw------- 1 root root 645 Sep 10 2013 authkeys

-rw-r--r-- 1 root root 10539 Sep 10 2013 ha.cf

-rwxr-xr-x 1 root root 745 Sep 10 2013 harc

-rw-r--r-- 1 root root 5905 Sep 10 2013 haresources

drwxr-xr-x 2 root root 4096 Dec 31 20:43 rc.d

-rw-r--r-- 1 root root 692 Sep 10 2013 README.config

drwxr-xr-x 2 root root 4096 Dec 31 20:43 resource.d

-rw-r--r-- 1 root root 7864 Sep 10 2013 shellfuncs

[root@stu21 ha.d]#

 

                配置文件:

            ha.cf: heartbeat的主配置文件;

            authkeys:集群信息加密算法及密钥;

            haresources: heartbeat v1的CRM配置接口;

---------------------------------------------------------------------------------------------------------------------------------

        

[root@stu21 ha.d]# vim ha.cf    

logfile /var/log/ha-log(开启)

#

#

# Facility to use for syslog()/logger

#

#logfacility local0(关闭)//如果要开启,则需要在 /etc/rsyslog.conf 增加一条 local0.* /var/log/heartbeat.log

.

.

    mcast eth0 227.203.101.1 694 1 0(开启多播地址,集群,得在默认下修改)

 

#node ken3

#node kathy

node node1.stu21.com (节点1 uname -n)

node node2.stu21.com(节点2 )

 

 

        #ping 10.10.10.254

ping 172.16.0.1

 

 

compression bz2

#

# Confiugre compression threshold

# This value determines the threshold to compress a message,

# e.g. if the threshold is 1, then any message with size greater than 1 KB

# will be compressed, the default is 2 (KB)

compression_threshold 2

 

---------------------------------------------------------------------------------------------------------------------------------

[root@node1 ~]# openssl rand -hex 6

89b3938df5e8

[root@node1 ~]#

[root@stu21 ha.d]# ls

authkeys ha.cf harc haresources rc.d README.config resource.d shellfuncs

[root@stu21 ha.d]# vim authkeys

 

#auth 1

#1 crc

#2 sha1 HI!

#3 md5 Hello!

auth 2

2 sha1 89b3938df5e8

 

[root@stu21 ha.d]# vim haresources

#node1 10.0.0.170 Filesystem::/dev/sda1::/data1::ext2

#

# Regarding the node-names in this file:

#

# They must match the names of the nodes listed in ha.cf, which in turn

# must match the `uname -n` of some node in the cluster. So they aren't

#virtual in any sense of the word.

node1.stu21.com 172.16.21.35/16/eth0/172.16.255.255 httpd(只加这一句)

 

 

接下来同样复制一份给节点 node2

 

[root@stu21 ha.d]# scp -p authkeys haresources ha.cf node2:/etc/ha.d/

authkeys 100% 672 0.7KB/s 00:00

haresources 100% 5968 5.8KB/s 00:00

ha.cf 100% 10KB 10.4KB/s 00:00

[root@stu21 ha.d]#

 

 

下面来测试两节点的web服务器是否正常

测试节点1(172.16.21.6)

    [root@stu21 ha.d]# service nginx start

Starting nginx: [ OK ]

[root@stu21 ha.d]# curl 172.16.21.6

<h1>www.stu21.com /nginx </h1>

[root@stu21 ha.d]# service nginx stop

Stopping nginx: [ OK ]

[root@stu21 ha.d]# chkconfig nginx off

[root@stu21 ha.d]# chkconfig --list nginx

nginx     0:off    1:off    2:off    3:off    4:off    5:off    6:off

[root@stu21 ha.d]#

 

测试节点2(172.16.21.10)

    [root@stu21 ~]#

[root@stu21 ~]# curl 172.16.21.10

<h1>node2.stu21.com /nginx </h1>

[root@stu21 ~]# service nginx stop

Stopping nginx: [ OK ]

[root@stu21 ~]# chkconfig nginx off

[root@stu21 ~]# chkconfig --list nginx

nginx     0:off    1:off    2:off    3:off    4:off    5:off    6:off

[root@stu21 ~]#

 

 

 

[root@stu21 ~]# service heartbeat start;ssh node2 'service heartbeat start'

 

 

 

 

 

 

 

LVS-HA的更多相关文章

  1. Ping CAP CTO、Codis作者谈redis分布式解决方案和分布式KV存储

    此文根据[QCON高可用架构群]分享内容,由群内[编辑组]志愿整理,转发请注明出处. 苏东旭,Ping CAP CTO,Codis作者 开源项目Codis的co-author黄东旭,之前在豌豆荚从事i ...

  2. [转载] Codis作者黄东旭细说分布式Redis架构设计和踩过的那些坑们

    原文: http://mp.weixin.qq.com/s?__biz=MzAwMDU1MTE1OQ==&mid=208733458&idx=1&sn=691bfde670fb ...

  3. 转:linux运维工程师

    运维中关键技术点解剖:1 大量高并发网站的设计方案:2 高可靠.高可伸缩性网络架构设计:3 网站安全问题,如何避免被黑?4 南北互联问题,动态CDN解决方案:5 海量数据存储架构 一.什么是大型网站运 ...

  4. 面试 Linux 运维工作至少需要知道哪些知识?

    前言 我们已经发过不少 Linux 面试题,但是单独的面试题总感觉会过于零碎,没有体系化内容给人的帮助大. 知乎上有这样一个问题:一个新手面试 Linux 运维工作至少需要知道哪些知识?其中有一个答案 ...

  5. Linux运维工程师应具备哪些技能?

      对于我们这些刚入门的运维小白来说,极强的好奇心总会驱使我们去涉猎各种技术,弄到最后很可能该学的知识半懵半解,知识体系混乱,学习毫无章法.因此,我们学习 时要有一个明确的目标和知识体系(也是我学习的 ...

  6. RabbitMQ系列之高可用集群

    为了实现高可用,我采用LVS+双节点RabbitMq , 架构图如下: 在RabbitMQ之前放了LVS, LVS 采用 rr 轮询算法 , 目的是将请求平均分配到两个真实节点,并配置5672端口监控 ...

  7. linux运维文章

    运维中关键技术点解剖:1 大量高并发网站的设计方案 :2 高可靠.高可伸缩性网络架构设计:3 网站安全问题,如何避免被黑?4 南北互联问题,动态CDN解决方案:5 海量数据存储架构 一.什么是大型网站 ...

  8. Linux运维发展与学习路线图

    记录一下Linux所要懂的知识体系,方便未来学习的时候自我验证. Linux运维课程体系大纲: Linux入门 了解Linux基础,知道什么是Linux,会安装Linux,使用相关基础命令,如:cd, ...

  9. HAProxy教程收集

    市面上HA的教程不是很多,基本都是基于LVS+HA实践的打包资料. 要最权威的文档应该去官方. 官方文档入口: http://www.haproxy.org/#docs 中文文档收集: http:// ...

  10. Linux运维工程师学习大纲

    linux运维课程大纲: Linux运维: Linux系统管理: Linux服务及安全管理: httpd,lamp,lnmp cache:memcached,varnish DB:mysql(mari ...

随机推荐

  1. UML 之 各种视图简介

    统一建模语言(Unified Modeling Language,UML)中各种视图并没有明显的概念区别. 在最上一层,视图被划分为三个视图域:结构,动态行为,模型管理. 结构主要描述了系统中的结构成 ...

  2. LOG4NET开源日志dll引用流程,在net3.5中已经实践ok

    一,在app.config中配置 <?xml version="1.0"?><configuration> <configSections> & ...

  3. TextRank算法提取关键词的Java实现

    转载:码农场 » TextRank算法提取关键词的Java实现 谈起自动摘要算法,常见的并且最易实现的当属TF-IDF,但是感觉TF-IDF效果一般,不如TextRank好. TextRank是在 G ...

  4. GOF设计模式之1:单例设计模式

    1.单例设计模式核心作用: 保证一个类只有一个实例,并且提供了访问该实例的全局访问点 2.常见应用场景: window的任务管理器 项目中读取配置文件一般也是一个单例模式 数据库连接池的设计也是采用单 ...

  5. IOS 按比例裁剪图片

    拍照或者从图片库中获取图片 操作过程中容易闪退,也总会有内存压力警告,第一步,首先可以考虑裁剪图片,实际上可能不需要那么大的.其次可以考虑把耗时的比如存储过程放进线程. 这里封装裁剪图片的类方法. / ...

  6. iOS-UISearchBar和UISearchController(参考网友来练习一下)

    #import "ViewController.h" #import "TestCell.h" @interface ViewController ()< ...

  7. [Arduino] 基于Xbee Pro和网络技术的智能公交系统设计

    转自:http://www.21ic.com/app/rf/201112/99474.htm 引言 公共交通具有个体交通无法比拟的强大优势,优先发展城市公共交通系统是解决大.中城市交通问题的最佳途径. ...

  8. 【高德地图开发4】---增加覆盖物setMapTextZIndex

    高德地图 Android SDK 允许用户将添加的线.面等覆盖物设置在地图底图文字的上方或下方. 具体实现是使 用 AMap 类的 setMapTextZIndex() 方法来设置地图底图文字的z轴指 ...

  9. PSI在windows server2008服务器上的安装方法

    PSI(http://www.oschina.net/p/psi-crm)是一款开源进销存软件,功能较为齐全,使用比较方便.在windows server2008系统中安装时遇到了一些问题,总结解决方 ...

  10. 程序员新人怎样在复杂代码中找 bug?

    分享下我的debug的经验 1. 优先解决那些可重现的,可重现的bug特别好找,反复调试测试就好了,先把好解决的干掉,这样最节约时间. 2. 对于某些bug没有头绪或者现象古怪不知道从哪里下手,找有经 ...