haproxy+keepalived部署

 

VIP1:10.90.11.196linux

VIP2:10.90.11.195redis

DIP1:10.90.11.96vim

DIP2:10.90.11.95tcp

 

keepalived部署spa

Director一、Director2:debug

yum install keepalived -yrest

vim /etc/keepalived/keepalived.confrouter

10.90.11.96
10.90.11.95

global_defs {
#notification_email {
1987277672@qq.com
#}
#notification_email_from root@localhost.com
#smtp_server 127.0.0.1
#smtp_connect_timeout 30
router_id HAPROXY_RECOM_MASTER
}server


vrrp_instance VI_1 {
state MASTER
interface bond0
virtual_router_id 71
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.90.11.196
}
}ip

vrrp_instance VI_2 {
state BACKUP
interface bond0
virtual_router_id 72
priority 90
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.90.11.195
}
}

global_defs {
#notification_email {
1987277672@qq.com
#}
#notification_email_from root@localhost.com
#smtp_server 127.0.0.1
#smtp_connect_timeout 30
router_id HAPROXY_RECOM_BACKUP
}


vrrp_instance VI_1 {
state BACKUP
interface bond0
virtual_router_id 71
priority 90
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}

virtual_ipaddress {
10.90.11.196
}
}

vrrp_instance VI_2 {
state MASTER
interface bond0
virtual_router_id 72
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.90.11.195
}
}

啓動keepalived

/etc/init.d/keepalived start

部署haproxy

director一、director2:

安裝haproxy:

wget http://pkgs.fedoraproject.org/repo/pkgs/haproxy/haproxy-1.6.9.tar.gz/c52eee40eb66f290d6f089c339b9d2b3/haproxy-1.6.9.tar.gz
tar zxf haproxy-1.6.9.tar.gz -C /usr/local/
cd /usr/local/haproxy-1.6.9
make TARGET=linux2628 ARCH=x86_64 PREFIX=/usr/local/haproxy
make install PREFIX=/usr/local/haproxy

修改配置文件:
vim /usr/local/haproxy/haproxy.cfg

global
log 127.0.0.1 local0
log 127.0.0.1 local1 notice
ulimit-n 40960
maxconn 4000
pidfile /usr/local/haproxy/haproxy.pid
#user haporxy
nbproc 2
daemon
defaults
mode tcp
option redispatch
option abortonclose
retries 3
timeout http-request 300s
timeout queue 1m
timeout connect 300s
timeout client 1m
timeout server 1m
timeout http-keep-alive 300s
timeout check 300s
maxconn 4096

listen tcptest
bind *:8180
balance roundrobin
mode tcp
option tcplog
log 127.0.0.1 local0 debug
server s1 10.80.29.142:8180 weight 1
server s2 10.80.30.142:8180 weight 1
server s3 10.80.31.142:8180 weight 1

 

啓動
/usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/haproxy.cfg
重啓
/usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/haproxy.cfg -st `cat /usr/local/haproxy/haproxy.pid`
中止
killall haproxy

將haproxy加入到系統服務中。腳本內容以下

vim /etc/init.d/haproxy

腳本內容以下:

#! /bin/sh
set -e

#PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/haproxy/sbin
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin:/usr/local/haproxy/sbin
PROGDIR=/usr/local/haproxy
PROGNAME=haproxy
DAEMON=$PROGDIR/sbin/$PROGNAME
CONFIG=$PROGDIR/$PROGNAME.cfg
PIDFILE=$PROGDIR/$PROGNAME.pid
DESC="HAProxy daemon"
SCRIPTNAME=/etc/init.d/$PROGNAME

# Gracefully exit if the package has been removed.
test -x $DAEMON || exit 0

start()
{
echo -e "Starting $DESC: $PROGNAME"
$DAEMON -f $CONFIG
echo "."
}

stop()
{
echo -e "Stopping $DESC: $PROGNAME"
haproxy_pid="$(cat $PIDFILE)"
kill $haproxy_pid
echo "."
}

restart()
{
echo -e "Restarting $DESC: $PROGNAME"
$DAEMON -f $CONFIG -p $PIDFILE -sf $(cat $PIDFILE)
echo "."
}

case "$1" in
start)
start
;;
stop)
stop
;;
restart)
restart
;;
*)
echo "Usage: $SCRIPTNAME {start|stop|restart}" >&2
exit 1
;;
esac

exit 0

相關文章
相關標籤/搜索