设为首页 收藏本站
查看: 1144|回复: 0

[经验分享] Rhel6-keepalived+lvs配置文档

[复制链接]

尚未签到

发表于 2015-9-4 09:19:26 | 显示全部楼层 |阅读模式
系统环境: rhel6 x86_64 iptables and selinux disabled
主机: 192.168.122.119 server19.example.com
192.168.122.25 server25.example.com
192.168.122.163 server63.example.com
192.168.122.193 server93.example.com
所需的包:keepalived-1.2.7.tar.gz


Realserver1192.168.122.163:apache
Realserver2192.168.122.193:apache
LoadBalance 192.168.122.119:keepalived
LoadBalance 192.168.122.25:keepalived
VirtualIP 192.168.122.178


以下步骤在server19server25上实施:
[iyunv@server19~]# yum install kernel-devel make gcc -y
[iyunv@server19~]# yum install openssl-devel popt-devel -y
[iyunv@server19~]# yum install libnl-devel -y


以下步骤在server19server25上实施:
[iyunv@server19kernel]# tar zxf keepalived-1.2.7.tar.gz
[iyunv@server19kernel]# cd keepalived-1.2.7
[iyunv@server19keepalived-1.2.7]# ./configure –prefix=/usr/local/keepalived
[iyunv@server19keepalived-1.2.7]# make && make install
[iyunv@server19keepalived-1.2.7]# scp -r /usr/local/keepalived/root@192.168.122.25:/usr/local/


以下步骤在server19server25上实施:
[iyunv@server19keepalived-1.2.7]# ln -s /usr/local/keepalived/etc/keepalived/ /etc/
[iyunv@server19keepalived-1.2.7]# ln -s/usr/local/keepalived/etc/sysconfig/keepalived  /etc/sysconfig/
[iyunv@server19keepalived-1.2.7]# ln -s/usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/
[iyunv@server19keepalived-1.2.7]# ln -s /usr/local/keepalived/sbin/keepalived /sbin/
注:系统镜像的负载均衡套件中也集成了keepalived,也可以直接使用yuminstall keepalived -y进行安装。但需先配置yum源:
[LoadBalancer]
name=InstructorServer Repository
baseurl=ftp://192.168.122.1/pub/yum/LoadBalancer
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release
enabled=1


以下步骤在server19实施:
[iyunv@server19~]# vim /etc/keepalived/keepalived.conf
global_defs{
notification_email {
root@localhost 错误发送至此邮箱
}
notification_email_from keepalived@server19.example.com发信人
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}


vrrp_instanceVI_1 {
state MASTER     角色:(1)MASTER(2)BACKUP
interface eth0
virtual_router_id 51   (主备的配置需要一致)
priority 100     优先级(数字越大,优先级越高)
advert_int 1     
authentication {
auth_type PASS    认证类型
auth_pass 1111    认证密码
}
virtual_ipaddress {
192.168.122.178    虚拟IP,可设置多个
}
}


virtual_server192.168.122.178 80 {
delay_loop 6
lb_algo rr
lb_kind DR
#nat_mask 255.255.255.0
#persistence_timeout 50
protocol TCP
real_server 192.168.122.163 80 {
weight 1
  TCP_CHECK {(注:TCP_CHECK和大括号之间要有空格)
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}


real_server 192.168.122.193 80 {
weight 1
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}

以下步骤在server25实施:
[iyunv@server25~]# vim /etc/keepalived/keepalived.conf
global_defs{
notification_email {
root@localhost  错误发送至此邮箱
}
notification_email_from keepalived@server25.example.com发信人
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}


vrrp_instanceVI_1 {
state BACKUP     角色:(1)MASTER(2)BACKUP
interface eth0
virtual_router_id 51 (主备的配置需要一致)
priority 50     优先级(数字越大,优先级越高)
advert_int 1
authentication {
auth_type PASS    认证类型
auth_pass 1111    认证密码
}
virtual_ipaddress {
192.168.122.178   虚拟IP,可设置多个
}
}


virtual_server192.168.122.178 80 {
delay_loop 6
lb_algo rr
lb_kind DR
#nat_mask 255.255.255.0
#persistence_timeout 50
protocol TCP
real_server 192.168.122.163 80 {
weight 1
  TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}


real_server 192.168.122.193 80 {
weight 1
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}


以下步骤在server63上实施:
[iyunv@server63~]# yum install arptables_jf httpd -y
[iyunv@server63~]# arptables -A IN -d 192.168.122.178 -j DROP
[iyunv@server63~]# arptables -A OUT -s 192.168.122.178 -j mangle --mangle-ip-s192.168.122.163
[iyunv@server63~]# /etc/init.d/arptables_jf save


[iyunv@server63~]# ifconfig eth0:0 192.168.122.178 netmask 255.255.255.255 up

[iyunv@server63~]# ip addr add 192.168.122.178 dev eth0
注:可用ipaddr show查看


[iyunv@server63~]# echo `hostname` > /var/www/html/index.html
[iyunv@server63~]# /etc/init.d/httpd start

以下步骤在server93上实施:
[iyunv@server93~]# yum install arptables_jf httpd -y
[iyunv@server93~]# arptables -A IN -d 192.168.122.178 -j DROP
[iyunv@server93~]# arptables -A OUT -s 192.168.122.178 -j mangle --mangle-ip-s192.168.122.193
[iyunv@server93~]# /etc/init.d/arptables_jf save

[iyunv@server93~]# ifconfig eth0:0 192.168.122.178 netmask 255.255.255.255 up

[iyunv@server93~]# ip addr add 192.168.122.178 dev eth0
注:可用ipaddr show查看


[iyunv@server93~]# echo `hostname` > /var/www/html/index.html
[iyunv@server93~]# /etc/init.d/httpd start


以下步骤在server19server25上实施:
[iyunv@server19~]# /etc/init.d/keepalived start


测试:
执行ipaddr show可查看虚拟IP,执行ipvsadm-l查看规则是否加载,访问192.168.122.178反复刷新网页,每次出现的页面都不同说明配置成功.当主备挂掉后可由另一台接管,当两台都正常时由Master充当调度器.


#配置多个服务(apache+ftp
以下步骤在server19实施:
[iyunv@server19~]# vim /etc/keepalived/keepalived.conf
global_defs{
notification_email {
root@localhost
}
notification_email_from keepalived@server19.example.com
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}


vrrp_instanceVI_1 {
state MASTER
interface eth0
virtual_router_id 51 (主备的配置需要一致)
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.122.178   虚拟IP,可设置多个
}
}


virtual_server192.168.122.178 80 {
delay_loop 6
lb_algo rr
lb_kind DR
#nat_mask 255.255.255.0
#persistence_timeout 50
protocol TCP
real_server 192.168.122.163 80 {
weight 1
  TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}


real_server 192.168.122.193 80 {
weight 1
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}


virtual_server192.168.122.178 21 {
delay_loop 6
lb_algo rr
lb_kind DR
#nat_mask 255.255.255.0
persistence_timeout 50  持续连接时间为50s
protocol TCP


real_server 192.168.122.163 21 {
weight 1
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}


real_server 192.168.122.193 21 {
weight 1
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}

以下步骤在server25实施:
[iyunv@server25~]# vim /etc/keepalived/keepalived.conf
global_defs{
notification_email {
root@localhost
}
notification_email_from keepalived@server25.example.com
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}


vrrp_instanceVI_1 {
state BACKUP
interface eth0
virtual_router_id 51 (主备的配置需要一致)
priority 50
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.122.178   虚拟IP,可设置多个
}
}


virtual_server192.168.122.178 80 {
delay_loop 6
lb_algo rr
lb_kind DR
#nat_mask 255.255.255.0
#persistence_timeout 50
protocol TCP
real_server 192.168.122.163 80 {
weight 1
  TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}


real_server 192.168.122.193 80 {
weight 1
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}


virtual_server192.168.122.178 21{
delay_loop 6
lb_algo rr
lb_kind DR
#nat_mask 255.255.255.0
persistence_timeout 50
protocol TCP


real_server 192.168.122.163 21 {
weight 1
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}


real_server 192.168.122.193 21 {
weight 1
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}


以下步骤在server63上实施:
[iyunv@server63~]# yum install arptables_jf httpd vsftpd -y
[iyunv@server63~]# arptables -A IN -d 192.168.122.178 -j DROP
[iyunv@server63~]# arptables -A OUT -s 192.168.122.178 -j mangle --mangle-ip-s192.168.122.163
[iyunv@server63~]# /etc/init.d/arptables_jf save


[iyunv@server63~]# ifconfig eth0:0 192.168.122.178 netmask 255.255.255.255 up

[iyunv@server63~]# ip addr add 192.168.122.178 dev eth0
注:可用ipaddr show查看


[iyunv@server63~]# echo `hostname` > /var/www/html/index.html
[iyunv@server63~]# /etc/init.d/httpd start
[iyunv@server63~]# touch /var/ftp/server63
[iyunv@server63~]# /etc/init.d/vsftpd start

以下步骤在server93上实施:
[iyunv@server93~]# yum install arptables_jf httpd vsftpd -y
[iyunv@server93~]# arptables -A IN -d 192.168.122.178 -j DROP
[iyunv@server93~]# arptables -A OUT -s 192.168.122.178 -j mangle --mangle-ip-s192.168.122.193
[iyunv@server93~]# /etc/init.d/arptables_jf save


[iyunv@server93~]# ifconfig eth0:0 192.168.122.178 netmask 255.255.255.255 up

[iyunv@server93~]# ip addr add 192.168.122.178 dev eth0
注:可用ipaddr show查看


[iyunv@server93~]# echo `hostname` > /var/www/html/index.html
[iyunv@server93~]# /etc/init.d/httpd start
[iyunv@server93~]# touch /var/ftp/server93
[iyunv@server93~]# /etc/init.d/vsftpd start

以下步骤在server19server25上实施:
[iyunv@server19~]# /etc/init.d/keepalived start

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-109239-1-1.html 上篇帖子: LVS+DR+Keepalived实现方式 下篇帖子: 借助LVS+Keepalived实现负载均衡(转)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表