cheng029 发表于 2014-7-4 15:30:49

基于heartbeatV2版本的ha-gui工具对httpd做高可用集群(2)

一、对MariaDB做高可用集群
    1.环境规划

    我们通过192.168.1.231对外提供MariaDB提供服务,两个客户端的ip地址分别为192.168.1.200和192.168.1.201,在192.168.1.204上提供了nfs服务为两台数据库提供共享存储
    2.准备共享目录

1
/data 192.168.1.0/24(rw,no_root_squash)




    3.在创建用户使其能够uid相同   

1
2
# groupadd -r -g 306 mysql
# useradd -r -g mysql -u 306 mysql




    4.数据库初始化


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# groupadd -r -g 306 mysql
# useradd -r -g mysql -u 306 mysql
# mount -t nfs 192.168.1.202:/data /mydata
# mkdir /mydata/{data,log}
# chown mysql.mysql /mydata/ -R
# tar xf mariadb-10.0.10-linux-x86_64.tar.gz -C /usr/local/
# cd /usr/local/
# ln -s mariadb-10.0.10-linux-x86_64 mysql
# cd mysql/
# chown mysql.root * -R
# cp support-files/my-large.cnf /etc/my.cnf
并修改配置文件
thread_concurrency = 4
datadir=/mydata/data
log-bin=/mydata/logs/mysql-bin
innodb_file_per_table = ON
# cp support-files/mysql.server /etc/init.d/mysqld
# chmod +x /etc/init.d/mysqld
初始化数据库
# scripts/mysql_install_db --user=mysql --datadir=/mydata/data/




   切记:现在就不需要在节点2上初始化数据了,节点2上的配置文件要跟节点1上保持一致

    5.配置权限

1
2
MariaDB> grant all on *.* to 'wangfeng7399'@'192.168.1.231' identified by 'wangfeng7399';
MariaDB> flush privileges;




    6.配置集群
      添加一个mariadbservice的组,用来存放关于mariadb定义的资源





    7测试

    先创建一个数据库


    此处我们将node2节点关掉


    在node1上登陆查看



    也可以看到我们创建的数据库

二、对LVS做高可用集群
    1.环境规划

我们通过192.168.1.232对外提供LVS提供服务,两台DS的地址分别为192.168.1.200和192.168.1.201,两个RealServer的ip地址分别为192.168.1.204和192.168.1.202
    2.在RealServer上配置LVS的服务,两台的配置方法相同


1
2
3
4
5
6
7
8
# echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
# echo 1 > /proc/sys/net/ipv4/conf/eth0/arp_ignore
# echo 2 > /proc/sys/net/ipv4/conf/eth0/arp_announce
# echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
# ifconfig lo:0 192.168.1.232 netmask 255.255.255.255 broadcast 192.168.1.232 up
# route add -host 192.168.1.232 lo:0
启动httpd服务
# service httpd start




    3.在两台DS上安装基于lvs的rpm包,如果不安装官方给的文档,要自己书写配置文档,有点麻烦,ldirectord还会检测RealServer的健康状态

1
2
3
4
#yum install -y heartbeat-ldirectord-2.1.4-12.el6.x86_64.rpm
最好是通过yum安装,这样可以解决依赖关系
chkconfig ldirectord off
关闭开机自启动




    4.准备配置文件


1
# cp /usr/share/doc/heartbeat-ldirectord-2.1.4/ldirectord.cf /etc/ha.d/




    5.修改配置文件


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
checktimeout=3检查超时时间
checkinterval=1 每个多长时间检测一次心跳
fallback=127.0.0.1:80 如果都失败了,会转移到被本机的web服务上
autoreload=yes 配置文件会不会自动装载
logfile="/var/log/ldirectord.log" 日志文件
#logfile="local0" 或者使用syslog
#emailalert="admin@x.y.z"
#emailalertfreq=3600
#emailalertstatus=all
quiescent=yes 是否使用静默模式
virtual=192.168.1.232:80 定义VIP与端口
      real=192.168.1.204:80 gate RealServer的ip地址 gate表示DR
      real=192.168.1.202:80 gate
      fallback=127.0.0.1:80 gate 如果所有的检查失败,使用的页面
      service=http 基于那种方式做监控检查
      request=".health.html" 监控检查的文件
      receive="wangfeng7399" 检查的内容
      scheduler=rr 调度算法
      #persistent=600 定义持久连接时间
      netmask=255.255.255.255 定义子网掩码




      说明:定义时,只能virtual顶个写,其余的都要空一个制表符,要不会出现语法错误   
    6.在各Real Server上添加.health.html内容为wangfeng7399
    7.在DS上准备一个错误页面,内容为“维护时间”,并启动web服务

    8.配置服务




    9.测试

      通过ipvsadm查看


    通过网页查看

    我们将web1关掉,依次来模拟一台Real Server 坏掉


我们将两台服务器都关掉

    通过web查看,为我们在DS上定义的页面

    我们启动其中任何一台,在查看


    都不会再看到我们定义的维护页面

    大功告成,由于本人水平有限,可能会有错误,请各位大神批评指正



页: [1]
查看完整版本: 基于heartbeatV2版本的ha-gui工具对httpd做高可用集群(2)