Centos 部署Keepalive高可用软件


一.环境介绍
 
1)Centos6.4
 
2) keepalived-1.2.12
 
3) 主备机的ip
 
Master:172.31.100.5
 
Slave: 172.31.100.54
 
Virtault ip:172.31.100.1
 
二.部署安装
 
计划具体部署步骤:
 
步骤1:安装
 
步骤2:配置
 
步骤3:运行
 
步骤4:检查
 
现在开始:
 
1)安装
 
$ yum install -y gcc make openssl openssl-devel
$ wget http://www.keepalived.org/software/keepalived-1.2.12.tar.gz
$ tar zxvf keepalived-1.2.12.tar.gz
$ cd keepalived-1.2.12
$ ./configure --prefix=/usr/local/keepalived
$ make && make install
 
2)配置
 
$ cp /usr/local/keepalived/sbin/keepalived /usr/sbin/
$ cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
$ cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/
$ cp -rf /usr/local/keepalived/etc/keepalived /etc/
 
A)Master:
$ vi /etc/keepalived/keepalived.conf
! Configuration File for keepalived

global_defs { 
   router_id LVS_DEVEL 
} 

vrrp_script chk_haproxy { 
          script "/etc/keepalived/chk_haproxy.sh" 
          interval 2 
          weight 2 
} 

vrrp_instance VI_1 { 
          interface eth0
          state BACKUP
          priority 101
          virtual_router_id 50
          garp_master_delay 1

          authentication { 
                      auth_type PASS 
                      auth_pass Hc8scrRddsLsc3
          } 

          virtual_ipaddress { 
                      172.31.100.1
          } 

          track_script { 
                      chk_haproxy
          } 

        #notify_master "/etc/keepalived/Mailnotify.py backup"
        #notify_backup "/etc/keepalived/Mailnotify.py master"
        #notify_fault "/etc/keepalived/Mailnotify.py fault" 

}

 

 
B)Slave:
 
$ vi /etc/keepalived/keepalived.conf

! Configuration File for keepalived

global_defs { 
   router_id LVS_DEVEL 
} 

vrrp_script chk_haproxy { 
          script "/etc/keepalived/chk_haproxy.sh" 
          interval 2 
          weight 2 
} 

vrrp_instance VI_1 { 
          interface eth0
          state BACKUP
          priority 100
          virtual_router_id 50
          garp_master_delay 1

          authentication { 
                      auth_type PASS 
                      auth_pass Hc8scrRddsLsc3
          } 

          virtual_ipaddress { 
                      172.31.100.1
          } 

          track_script { 
                      chk_haproxy
          } 

        notify_master "/etc/keepalived/Mailnotify.py backup"
        notify_backup "/etc/keepalived/Mailnotify.py master"
        #notify_fault "/etc/keepalived/Mailnotify.py fault" 

}

 

 
C)主备两边都需要的检测脚本和邮件报警脚本:
 
#keepalive调用该脚本检测haproxy是否停止
$ vi /etc/keepalived/chk_haproxy.sh
#!/bin/bash
status=$(ps aux|grep haproxy | grep -v grep | grep -v bash | wc -l)
if [ "${status}" = "0" ]; then
    /etc/init.d/haproxy start
    status2=$(ps aux|grep haproxy | grep -v grep | grep -v bash |wc -l)
    if [ "${status2}" = "0"  ]; then
            /etc/init.d/keepalived stop
    fi
fi

#邮件报警脚本 来自网络刘天斯大牛

$ vi /etc/keepalived/chk_haproxy.sh

#!/usr/bin/env python
#coding: utf-8 
from email.MIMEMultipart import MIMEMultipart 
from email.MIMEText import MIMEText 
from email.MIMEImage import MIMEImage 
from email.header import Header 
import sys 
import smtplib 

strFrom = 'xxxxx@126.com'      #邮件来自哪里
strTo = 'receive@gmail.com'    #收件箱
smtp_server='smtp.126.com'     #邮件服务器地址
smtp_user='send@126.com'       #发件箱
smtp_pass='passwdxx'           #密码


if sys.argv[1]!="master" and sys.argv[1]!="backup"  and sys.argv[1]!="fault": 
    sys.exit() 
else: 
    notify_type=sys.argv[1] 


mail_title='[紧急]负载均衡器邮件通知' 
mail_body_plain=notify_type+'被激活,请做好应急处理。' 
mail_body_html='<b><font color=red>'+notify_type+'被激活,请做好应急处理。</font></b>' 

msgRoot = MIMEMultipart('related') 
msgRoot['Subject'] =Header(mail_title,'utf-8') 
msgRoot['From'] = strFrom 
msgRoot['To'] = strTo 

msgAlternative = MIMEMultipart('alternative') 
msgRoot.attach(msgAlternative) 

msgText = MIMEText(mail_body_plain, 'plain', 'utf-8') 
msgAlternative.attach(msgText) 
msgText = MIMEText(mail_body_html, 'html','utf-8') 
msgAlternative.attach(msgText) 

smtp = smtplib.SMTP() 
smtp.connect(smtp_server) 
smtp.login(smtp_user,smtp_pass) 
smtp.sendmail(strFrom, strTo, msgRoot.as_string()) 
smtp.quit()

 

 
3)运行
 
$ /etc/init.d/keepalived start
$ chkconfig keepalived on
 
4)检查
 
$ ps aux|grep keeepalived #查看进程
$ ip addr show            #用来查看地址是否切换的
 
三.结尾
 
以上是该软件的全部部署过程

相关内容