操作思考:通过DRBD实现数据同步,通过Corosync+Pacemaker(下图简称CP)实现检测故障并转移,常规状态下仅其中一台工作,另一台仅检测和同步数据,当有故障时,Server2自动接管一切业务,并向另一台同步数据(当然,此时不一定能同步成功..)。图示如下:
 

 

操作环境:
rhel5.8 (光盘yum源)
192.168.88.20     demo1.mos.com   demo1
192.168.88.21     demo1.mos.com   demo2
内核:2.6.18-308.el5PAE
检查Selinux关闭之
检查Iptables清空之
若无特殊说明,笔者都在demo1(192.168.88.20)操作

所需软件包,笔者直接打包放到网盘了:
md5校验:6ac5ae5b40a1021e1fcc3ce6d372a6a7
http://pan.baidu.com/share/link?shareid=131508&uk=1678158691

第一步:设置实验环境(时间同步,双机互信,hosts解析)

1. demo1(192.168.88.21)操作如下:
 

 
  
  1. # ssh-keygen    (几下回车即可)  
  2. # cd /root/.ssh  
  3. # cat id_rsa.pub >> authorized_keys  
  4. # > known_hosts  
  5. # scp * 192.168.88.21:/root/.ssh/ (输入其密码) 
  6. # vim /etc/hosts
    192.168.88.20 demo1.mos.com demo1
    192.168.88.21 demo1.mos.com demo2
    # scp /etc/hosts demo2:/etc

    # vim /etc/sysconfig/network  (demo2上修改为demo2)
    NETWORKING=yes
    HOSTNAME=demo1.mos.com

2.时间同步,11281050等于11月28号10点50分
 

 
  
  1. # ssh demo2 'date 11281050'date 11281050 

第二步:安装配置DRBD


        DRBD(Distributed Replicated Block Device),类似于iSCSI,都是块级别的共享,都不能检测文件系统是否正常或崩溃,但是其默认的情况下的主从工作模式中,仅允许主服务的设备可以被操作,从设备仅接收主设备的所有数据更改,不能被程序操作,甚至读也不行。
在其主的一方故障时,由高可用集群软件迅速切换主从角色,以实现快速故障转移。其核心功能通过Linux内核实现。

1. 下载并安装所需软件包

 
  
  1. # mkdir pv /root/download     笔者软件目录  
  2. # cd /root/download  
  3. # tar xf all.tar.gz        上面链接里面的软件包  
  4. # yum -y --nogpgcheck localinstall *.rpm 

其实drbd只需要其中两个含有drbd名字的包即可,但是下几步操作会需要,便一起安装了,如果之前有安装过openais需删除,命令:yum remove openais -y

2. 复制配置文件模板,并创建自定义配置文件
 

 
  
  1. # cp /usr/share/doc/drbd83-8.3.8/drbd.conf  /etc  
  2. # vim /etc/drbd.d/global-common.conf 主配置文件,简单修改即可  
  3. global {  
  4.  usage-count no;  
  5. }  
  6. common {  
  7.  protocol C; #协议C,同步复制协议,保证数据的有效性,但占用带宽  
  8.  handlers {  
  9. ----此处两段不做修改即可,太多了不贴了  
  10.  disk {  
  11.   on-io-error detach;   对磁盘的定义,哪个IO错误就拆哪个  
  12.  }  
  13.  net {  
  14.   cram-hmac-alg "sha1";   #加密传输  
  15.   shared-secret "mydrbdlab";   #加密用的随机字符串  
  16.  }  
  17.  syncer {  
  18.   rate 100M;   #可用带宽多少  
  19.  }  
  20. }  
  21.  
  22. # vim /etc/drbd.d/http.res #定义http资源  
  23. resource http {  
  24.   device /dev/drbd1;  
  25.   disk /dev/sda6;  
  26.   meta-disk internal;  
  27.  on demo1.mos.com {  
  28.   address 192.168.88.20:7799;  
  29.  }  
  30.  on demo2.mos.com {  
  31.   address 192.168.88.21:7799;  
  32.  }  
  33. }  
  34.  
  35. # vim /etc/drbd.d/mysql.res  #定义mysql资源,效果一样  
  36. resource mysql {  
  37.  on demo1.mos.com {  
  38.   device /dev/drbd0;  
  39.   disk /dev/sda5;  
  40.   address 192.168.88.20:7789;  
  41.   meta-disk internal;  
  42.  }  
  43.  on demo2.mos.com {  
  44.   device /dev/drbd0;  
  45.   disk /dev/sda5;  
  46.   address 192.168.88.21:7789;  
  47.   meta-disk internal;  
  48.  }  

3. 创建drbd数据同步所需的分区
         demo1,demo2都要有,大小自定,但必须保持两个主机的磁盘大小和编号一致,笔者只给了1G,两个主机均为:/dev/sda5和/dev/sda6
这个笔者操作就不写了,真的需要的话,笔者的shell编程里面,有个能自动创建的磁盘分区,有兴趣的去看看,得改几个变量..

4. 将刚才的几个配置文件同步到demo2,并创建对应的drbd设备
 

 
  
  1. # scp /etc/drbd.conf demo2:/etc/  
  2. # scp /etc/drbd.d/* demo2:/etc/drbd.d/  
  3. # drbdadm create-md mysql  
  4. # drbdadm create-md http  
  5. # ssh demo2 'drbdadm create-md mysql' 
  6. # ssh demo2 'drbdadm create-md http' 

5. 启动服务,并格式化磁盘

 
  
  1. # service drbd start  
  2. # ssh demo2 'service drbd start' 
  3. # drbdsetup /dev/drbd0 primary -o #将本机的设置为主  
  4. # drbdsetup /dev/drbd1 primary -o  
  5. # watch -n1 'drbd-overview'  观察数据同步情况,ctrl+c退出。  
  6. # drbd-overview  #查看状态,当为下面内容时,进行下一步操作  
  7.   0:mysql  Connected Primary/Secondary UpToDate/UpToDate C r----  
  8.   0:http  Connected Primary/Secondary UpToDate/UpToDate C r----  
  9. # mke2fs -j /dev/drbd0  
  10. # mke2fs -j /dev/drbd1  
  11. # mount /dev/drbd0 /data/  #此处/data没有的话,自行创建 

6. 简单测试,正常后取消其开机自动启动,由于下一步需要,暂不停止服务
 

 
  
  1. # echo 'This is a test message' > /data/a.txt  
  2. # umount /data  
  3. # drbdadm secondary mysql   #drbd提供的管理工具,具体用法见man  
  4. # ssh demo2  
  5. # drbdadm Primary mysql  
  6. # mount /dev/drbd0 /data/  检查/data里面是否有a.txt,且自身是否可写即可  
  7. # echo 'This is a test message demo2' > /data/b.txt  
  8. # drbdadm secondary mysql  
  9. # umount /data && chkconfig drbd off  && logout  
  10. # drbdadm primary mysql  
  11. # drbdadm primary http  
  12. # chkconfig drbd off 

 7.  查看drbd状态及错误处理

如果遭遇如下图错误时,一般就是传说中闹裂了。

解决方法是,在你认为是备用数据的节点上执行如下操作:清空本地不一致数据

然后在主节点上重新连接资源即可:# drbdadm connect all

 

第三步: 安装Apache、MySQL和PHP及简单搭建一个Wordpress

1. MySQL安装,笔者偷个懒,直接下载的tar.gz,解压后,简单配置即可使用
 

 
  
  1. # cd ~/download  
  2. # wget http://cdn.mysql.com/Downloads/MySQL-5.5/mysql-5.5.28-linux2.6-i686.tar.gz  
  3. # tar xf mysql-5.5.28-linux2.6-i686.tar.gz -C /usr/local/  
  4. # cd /usr/local/  
  5. # ln -sv mysql-5.5.28-linux2.6-i686 mysql  
  6. # cd mysql  
  7. # useradd -r mysql # 必须保证两个节点的mysql用户的uid和gid一致  
  8. # chown -R root.mysql .   
  9. # mount /dev/drbd0 /data  
  10. # chown -R mysql. /data  
  11. # scripts/mysql_install_db --user=mysql --datadir=/data  
  12. # cp /usr/local/mysql/support-files/my-large.cnf  /etc/my.cnf  
  13. # vim /etc/my.cnf  
  14. thread_concurrency = 2 #修改  
  15. datadir = /data         #添加到[mysqld]段内即可  
  16. # cp /usr/local/mysql/support-files/mysql.server  /etc/rc.d/init.d/mysqld  
  17. # service mysqld start  
  18. # echo 'MANPATH  /usr/local/mysql/man' >> /etc/man.config  
  19. # ln -sv /usr/local/mysql/include  /usr/include/mysql  
  20. # echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf && ldconfig  
  21. # echo 'export PATH=$PATH:/usr/local/mysql/bin' > /etc/profile.d/mysql.sh  
  22. # . /etc/profile.d/mysql.sh  
  23. # service mysqld start  
  24. # mysql   <---直接敲回车,为wordpress提供数据库及认证信息  
  25. mysql> create database wp;  
  26. mysql> GRANT ALL ON wp.* TO 'blog'@'192.168.88.200' IDENTIFIED BY '123';  
  27. mysql> FLUSH PRIVILEGES ;  
  28. mysql> \q  
  29. # chkconfig --add mysqld  
  30. # chkconfig mysqld off 
  31. ----给demo2提供相关的mysql文件------------  
  32. # cd ~/download  
  33. # scp mysql-5.5.28-linux2.6-i686.tar.gz demo2:~/download/  
  34. # ssh demo2  
  35. # useradd -r mysql #请务必保证跟demo1的mysql的uid和gid一致  
  36. # tar xf mysql-5.5.28-linux2.6-i686.tar.gz -C /usr/local/  
  37. # echo 'MANPATH  /usr/local/mysql/man' >> /etc/man.config  
  38. # ln -sv /usr/local/mysql/include  /usr/include/mysql  
  39. # echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf && ldconfig  
  40. # echo 'export PATH=$PATH:/usr/local/mysql/bin' > /etc/profile.d/mysql.sh  
  41. # . /etc/profile.d/mysql.sh  
  42. # scp demo1:/etc/my.cnf /etc/  
  43. # chkconfig --add mysqld  
  44. # chkconfig mysqld off && logout  

 

2 .安装Apache、PHP和wordpress

 
  
  1. # yum install httpd php53 php53-mysql –y  
  2. # ssh demo2  'yum install httpd php53 php53-mysql –y' 
  3. # service httpd start  
  4. # mount /dev/drbd1 /var/www/html  
  5. # cd /var/www/html  
  6. # wget http://cn.wordpress.org/wordpress-3.4.2-zh_CN.tar.gz  
  7. # tar xf wordpress-3.4.2-zh_CN.tar.gz  
  8. # mv wordpress/* .  
  9. # cp wp-config-sample.php wp-config.php  
  10. # vim wp-config.php  #仅修改前四行有效行  
  11. define('DB_NAME''wp');  
  12. define('DB_USER''blog');  
  13. define('DB_PASSWORD''123');  
  14. define('DB_HOST''192.168.88.200');  
  15. ...........  
  16. # ifconfig eth0:0 192.168.88.200 

# 打开浏览器输入 http://192.168.88.200 输入用户名密码后稍作等待即可.

3. 在demo2做简单测试,仍直接在demo1上操作

 
  
  1. # cd  
  2. # service network restart  #清除刚才定义的网卡  
  3. # service mysqld stop  
  4. # service httpd stop  
  5. # umount /data && umount /var/www/html  
  6. # drbdadm secondary mysql  
  7. # drbdadm secondary http  
  8. # ssh demo2  
  9. # drbdadm primary mysql  
  10. # drbdadm primary http  
  11. # mount /dev/drbd0 /data  #/data若无,则自行创建  
  12. # mount /dev/drbd1 /var/www/html  
  13. # service mysqld start  
  14. # service httpd start  
  15. # ifconfig eth0:0 192.168.88.200/24 


至此,再次打开浏览器,查看http://192.168.88.200 若正常,则应该出现wordpress界面


第四步: 使用pacemaker的crm配置corosync
        配置高可用集群时,需确保所调用管理的服务,设备,IP等资源都处于没有使用以及没有开机启动状态。因此,第一步,检查并关闭所有之前开启的资源等。


1.检查并修改为节点所需状态
 

 
  
  1. # chkconfig httpd off && service httpd stop  
  2. # chkconfig mysqld off && service mysqld stop  
  3. # chkconfig drbd off && service drbd stop  
  4. # umount /data && umount /var/www/html  
  5. # ssh demo2  
  6. # chkconfig httpd off && service httpd stop  
  7. # chkconfig mysqld off && service mysqld stop  
  8. # chkconfig drbd off && service drbd stop  
  9. # umount /data && umount /var/www/html 

2.配置两个节点的corosync配置文件
 

 
  
  1. # cd /etc/corosync/  
  2. # cp corosync.conf.example corosync.conf  
  3. # vim corosync.conf  
  4. # Please read the corosync.conf.5 manual page  
  5. compatibility: whitetank  
  6. totem {  
  7.  version: 2  
  8.  secauth: on 
  9.  threads: 1  
  10.  interface {  
  11.   ringnumber: 0  
  12.   bindnetaddr: 192.168.88.1  
  13.   mcastaddr: 226.94.11.13  
  14.   mcastport: 5405  
  15.  }  
  16. }  
  17. logging {  
  18.  fileline: off 
  19.  to_stderr: no 
  20.  to_logfile: yes  
  21.  to_syslog: no 
  22.  logfile: /var/log/cluster/corosync.log  
  23.  debug: off 
  24.  timestampon 
  25.  logger_subsys {  
  26.   subsys: AMF  
  27.   debug: off 
  28.  }  
  29. }  
  30. amf {  
  31.  mode: disabled  
  32. }  
  33. service {  
  34.  var: 0  
  35.  name: pacemaker  
  36. }  
  37. aisexec {  
  38.  user: root  
  39.  group: root  
  40. }  
  41. # corosync-keygen  
  42. # mkdir /var/log/cluster  
  43. # ssh demo2 'mkdir /var/log/cluster' 
  44. # scp authkey corosync.conf demo2:/etc/corosync/  
  45. # service corosync start;ssh demo2 'service corosync start’ 

3. 各种约束,各种配置..
1) 实验环境,关闭stonith设备支持;并且,由于是两个节点的特殊高可用集群,因此也关闭quorum投票机制。
 

 
  
  1. # crm configure property stonith-enabled=false 
  2. # crm configure property no-quorum-policy=ignore 

2)配置DRBD资源,笔者更喜欢进入crm操作(你猜我会说是因为它能命令补全么..)..
 

 
  
  1. # crm   
  2. crm(live)# configure    
  3. crm(live)configure # primitive DRBD ocf:linbit:drbd params drbd_resource="mysql" op start interval="0" timeout="240" op stop interval="0" timeout="100" 
  4. crm(live)configure # primitive WEB ocf:linbit:drbd params drbd_resource="http" op start interval="0" timeout="240" op stop interval="0" timeout="100" 

3)配置DRDB资源为主从类资源(两个节点,只有一个能在工作状态)
 

 
  
  1. crm(live)configure # master MS_DRBD DRBD meta master-max="1" master-node-max="1" clone-max="2" clone-node-max="1" notify="true" 
  2. crm(live)configure # master MS_WEB WEB meta master-max="1" master-node-max="1" clone-max="2" clone-node-max="1" notify="true" 

4)配置存储类资源(LAMP所需的web文件和mysql数据)
 

 
  
  1. crm(live)configure # primitive FS ocf:heartbeat:Filesystem params device="/dev/drbd0" directory="/data" fstype="ext3" op start interval="0" timeout="60" op stop interval="0" timeout="60" 
  2. crm(live)configure # primitive WEBFS ocf:heartbeat:Filesystem params device="/dev/drbd1" directory="/var/www/html" fstype="ext3" op start interval="0" timeout="60" op stop interval="0" timeout="60" 

5)配置服务类资源和IP资源(LAMP所需的服务和IP)
 

 
  
  1. crm(live)configure # primitive HTTP lsb:httpd  
  2. crm(live)configure # primitive MySQL lsb:mysqld  
  3. crm(live)configure # primitive IP ocf:heartbeat:IPaddr2 params ip="192.168.88.200" 

6)配置位置约束(LAMP需要都运行在一起),以及考虑demo2性能略好于demo1,因此,尽量让服务都运行在demo2上。

 
  
  1. crm(live)configure # colocation FS_on_MS_DRBD inf: FS MS_DRBD:Master  
  2.   DRBD的mysql主资源要和使用的文件系统在一起  
  3. crm(live)configure # colocation HTTP_on_IP inf: HTTP IP  
  4.   网页和IP要在一起,约束了两个主资源在一起  
  5. crm(live)configure # colocation HTTP_on_WEBFS inf: WEBFS HTTP  
  6.   网页文件要和Apache在一起  
  7. crm(live)configure # colocation IP_with_MS_DRBD inf: IP MS_DRBD:Master  
  8.   IP要和MySQL资源在一起  
  9. crm(live)configure # colocation MySQL_with_FS inf: MySQL FS  
  10.   数据库服务要和其数据资源在一起  
  11. crm(live)configure # colocation WEBFS_on_MS_WEB inf: WEBFS MS_WEB:Master  
  12.   网页文件要和DRBD的http主资源在一起 
  13. crm(live)configure # location DEMO2 MS_DRBD inf: demo2.mos.com
  14. 只要有一点可能,就要让所有服务工作在 demo2.mos.com

7)配置启动次序约束(例如,如果MySQL数据没挂载,就启动MySQL服务..你懂的)
 

 
  
  1. crm(live)configure # order FS_after_MS_DRBD inf: MS_DRBD:promote FS:start  
  2.  DRBD的mysql资源为主,然后再挂载到/data  
  3. crm(live)configure # order WEBFS_after_MS_WEB inf: MS_WEB:promote WEBFS:start  
  4.  DRBD的http资源为主,然后再挂载/var/www/html  
  5. crm(live)configure # order MySQL_after_FS inf: FS MySQL  
  6.  MySQL数据挂载后,再启动MySQL服务  
  7. crm(live)configure # order HTTP_after_WEBFS inf: WEBFS HTTP  
  8.  网页文件挂载后再启动 

8) 检查语法是否错误,并提交操作

 
  
  1. crm(live)configure # verify  没提示,就是好消息  
  2. crm(live)configure # commit  提交 

9) 最后配置完成执行:# crm configure show   见下图:

 


4. 检查当前状态,并做简单测试即可
# crm status  #查看当前服务工作状态,如下图,也可以打开网页192.168.88.200查看是否工作
 
 

# crm node standby 模拟故障,可以看到demo1不在线,处于待命状态如下图:同时刷新网页,正常工作,没有问题,可以打开网页192.168.88.200查看是否正常


 
# crm node online 恢复demo1的状态为在线,然后就会又看到第一个图
# ssh demo2 'service corosync stop' 停止掉demo2的服务,查看如下:


 
此时服务又转移到demo1上去了..看,很神奇,不是吗…哈哈

对了,如果使用  crm status查看到如下错误时,使用: # crm resource cleanup NFS (NFS是笔者上次定义的资源,这个名字是自己取的)清除一下错误的资源缓存神马的...估计就问题不大了。见下图:

 

今天笔者实验时又遇到了这个问题,后来仔细排查,是因为 顺序约束有些逻辑冲突(A在B后启动,又在C后启动,C又在A后启动之类的错误,总之肯定会出事的),后来修改后就OK了…