1.高可用Heartbeat
興寧ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!
Server1和server4安裝資源包
heartbeat-3.0.4-2.el6.x86_64.rpm
heartbeat-devel-3.0.4-2.el6.x86_64.rpm
heartbeat-libs-3.0.4-2.el6.x86_64.rpm
ldirectord-3.9.5-3.1.x86_64.rpm
yum install -y heartbeat-*
[root@server1 ha.d]# cd /usr/share/doc/heartbeat-3.0.4/
[root@server1 heartbeat-3.0.4]# cp ha.cf authkeys haresources /etc/ha.d/
[root@server1 heartbeat-3.0.4]# cd /etc/ha.d
[root@server1 ha.d]# vim ha.cf
[root@server1 ha.d]# vim authkeys
[root@server1 ha.d]# chmod 600 authkeys
[root@server1 ha.d]# vim haresources
[root@server1 ha.d]# scp ha.cf authkeys haresources server4:/etc/ha.d
[root@server1 ha.d]# /etc/init.d/heartbeat start
Server4做相同的操作
[root@server4 ha.d]# /etc/init.d/heartbeat start
測(cè)試:
[root@server1 ha.d]# /etc/init.d/heartbeat stop
[root@server1 ha.d]# /etc/init.d/heartbeat start
1.ipvs負(fù)載均衡
首先停掉server1和server4上的heartbeat
Server1上的操作,并且server1做調(diào)度器
[root@server1 ~]# yum install -y ldirectord-3.9.5-3.1.x86_64.rpm
[root@server1 ~]# cd /usr/share/doc/ldirectord-3.9.5/
[root@server1 ldirectord-3.9.5]# cp ldirectord.cf /etc/ha.d
[root@server1 ~]# yum install -y ipvsadm
[root@server1 ~]# ipvsadm -L
[root@server1 ~]# ipvsadm -C ##清除規(guī)則
[root@server1 ~]# ipvsadm -A -t 172.25.6.100:80 -s rr ##rr表示采用輪詢調(diào)度算法,添加新的虛擬ip
[root@server1 ~]# ip addr add 172.25.6.100/24 dev eth0
[root@server1 ~]# ip addr
[root@server1 ~]# ipvsadm -a -t 172.25.6.100:80 -r 172.25.6.2:80 -g ##添加新規(guī)則
[root@server1 ~]# ipvsadm -a -t 172.25.6.100:80 -r 172.25.6.3:80 -g
[root@server1 ~]# /etc/init.d/ipvsadm save ##保存添加的規(guī)則
[root@server1 ~]# ipvsadm -L ##顯示內(nèi)核中虛擬服務(wù)器列表
[root@server1 ~]# /etc/init.d/httpd restart
Server2上的操作
[root@server2 ~]# ip addr add 172.25.6.100/32 dev eth0
[root@server2 ~]# ip addr
[root@server2 ~]# yum install -y arptables_jf
[root@server2 html]# arptables -A IN -d 172.25.6.100 -j DROP
[root@server2 html]# arptables -A OUT -s 172.25.6.200 -j mangle --mangle-ip-s 172.25.6.2
[root@server2 html]# /etc/init.d/arptables_jf save
[root@server2 html]# /etc/init.d/httpd restart
Server3上的操作
[root@server3 ~]# /etc/init.d/httpd start
[root@server3 ~]# ip addr add 172.25.6.100/32 dev eth0 ##給內(nèi)網(wǎng)網(wǎng)卡添加ip
[root@server3 ~]# ip addr
[root@server3 ~]# yum install -y arptables_jf
[root@server3 html]# arptables -A IN -d 172.25.6.100 -j DROP ##給這個(gè)地址追加策略
[root@server3 html]# arptables -A OUT -s 172.25.6.100 -j mangle --mangle-ip-s 172.25.6.3 ##追加策略,由100源地址跳到3上
[root@server3 ~]# /etc/init.d/arptables_jf save ##保存添加的策略
[root@server3 ~]# /etc/init.d/arptables_jf start
[root@server3 ~]# /etc/init.d/httpd restart
測(cè)試:
2.高可用與負(fù)載均衡
[root@server1 ~]# yum install -y ldirectord-3.9.5-3.1.x86_64.rpm
[root@server1 ~]# cd /etc/ha.d/
[root@server1 ha.d]# vim ldirectord.cf
[root@server1 ha.d]# ipvsadm -C ##清除策略
[root@server1 ha.d]# ipvsadm -L ##查看策略
[root@server1 ha.d]# ip addr del 172.25.6.100/24 dev eth0 ##刪除內(nèi)網(wǎng)網(wǎng)卡上的ip
[root@server1 ha.d]# vim haresources
[root@server1 ha.d]# scp haresources ldirectord.cf 172.25.6.4:/etc/ha.d/ ##server4上做與server1相同的操作
打開server4上的heartbeat替代server1的heartbeat
[root@server1 html]# /etc/init.d/httpd restart
測(cè)試:
如果server2和server3的httpd打開
如果server2和server3 httpd關(guān)閉,則訪問heartbeat所在的主機(jī)
4.keepalived
關(guān)閉server1和server4的heartbeat,打開server2和server3的httpd
Server1上的操作
[root@server1 ~]# tar zxf keepalived-1.2.20.tar.gz
[root@server1 ~]#cd keepalived-1.2.20/
[root@server1 keepalived-1.2.20]# ./configure --prefix=/usr/local/keepalived/ ##解譯到指定路徑
[root@server1 keepalived-1.2.20]# make && make install
[root@server1 keepalived-1.2.20]# cd /usr/local/keepalived/
[root@server1 local]# scp -r keepalived/ 172.25.6.4:/usr/local/
[root@server1 sbin]#
ln -s /usr/local/keepalived/sbin/keepalived /sbin/
[root@server1 etc]# ln -s /usr/local/keepalived/etc/keepalived/ /etc/
[root@server1 sysconfig]#
ln -s /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
[root@server1 sysconfig]#
ln -s /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/
[root@server1 init.d]# chmod +x keepalived
[root@server1 init.d]# cd /etc/keepalived/
[root@server1 keepalived]# ls
keepalived.conf samples
[root@server1 keepalived]# vim keepalived.conf
[root@server1 keepalived]# /etc/init.d/keepalived start
將修改的配置文件發(fā)送到server4同位置
Server4上的操作
[root@server4 keepalived]#
ln -s /usr/local/keepalived/sbin/keepalived /sbin/
[root@server4 keepalived]#
ln -s /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d
[root@server4 keepalived]#
chmod +x /usr/local/keepalived/etc/rc.d/init.d/keepalived
[root@server4 keepalived]#
ln -s /usr/local/keepalived/etc/sysconfig/keepalived /
etc/sysconfig/
[root@server4 keepalived]# /etc/init.d/keepalived start
[root@server4 keepalived]# mkdir /etc/keepalived/
將文件中的server1改為server4,state改為backup,
兩者的virtual_router_id一定不同,server4的priority值小于server1的值
將keepalived進(jìn)行重啟
測(cè)試: