前言:lvs和haproxy的区别
lvs:
1、抗负载能力强、是工作在网络4层之上仅作分发之用,没有流量的产生;
2、无流量,保证了均衡器IO的性能不会收到大流量的影响;
3、应用范围比较广,因为LVS工作在4层,所以它几乎可以对所有应用做负载均衡
4、工作稳定,因为其本身抗负载能力很强,自身有完整的双机热备方案,
如LVS+Keepalived,不过我们在项目实施中用得最多的还是LVS/DR+Keepalived。
Haproxy:
1、HAProxy也是支持虚拟主机的
HAProxy跟LVS类似,本身就只是一款负载均衡软件,基于七层;
2、单纯从效率上来讲HAProxy会比Nginx有更出色的负载均衡速度,
在并发处理上也是优于Nginx的;
3、HAProxy支持TCP协议的负载均衡转发,
可以对MySQL读进行负载均衡,对后端的MySQL节点进行检测和负载均衡
准备工作:
1、准备四台主机:IP地址规划是
4.49,4.50(haproxy),4.51(web),4.52(web)
2、在4.50 上安装haproxy软件,在4.51和4.52上
安装httpd软件
一、普通LB集群
1、修改配置文件:vim /etc/haproxy/haproxy.cfg
把60行以下的内容全部删除,增加下面的内容
stats uri /admin
60 listen lbweb 0.0.0.0:80
61 cookie SERVERID rewrite
62 balance roundrobin
63 server web51 192.168.4.51:80 cookie app51 check inter 2000 rise 2 fall 5
64 server web52 192.168.4.52:80 cookie app52 check inter 2000 rise 2 fall 5
2、可以去页面查看健康性:http://192.168.4.50/admin
3、测试:停掉其中一台web服务器,去后台查看后台的session会话的次数
二、区分业务的LB集群
1、用四台服务器测试
4.51和4.52做html负载,4.53和4.54做php的负载
2、上面4.51和4.52已经做好了,现在把4.53和4.54做好php的网站
3、修改配置文件:vim /etc/haproxy/haproxy.cfg
59 stats uri /admin
60 #---------------------------------------------------------------------
61 # main frontend which proxys to the backends
62 #---------------------------------------------------------------------
63 frontend weblb 192.168.4.100:80
64 # acl url_static path_beg -i /static /images /javascript /stylesheets
65 acl path_html path_end -i .html
66 acl path_php path_end -i .php
67
68 use_backend htmlg if path_html
69 use_backend phpg if path_php
70 default_backend htmlg
71
72 #---------------------------------------------------------------------
73 # static backend for serving up images, stylesheets and such
74 #---------------------------------------------------------------------
75 #backend static
76 # balance roundrobin
77 # server static 127.0.0.1:4331 check
78
79 #---------------------------------------------------------------------
80 # round robin balancing between the various backends
81 #---------------------------------------------------------------------
82 backend htmlg
83 balance roundrobin
84 server app101 192.168.4.101:80 check
85 server app102 192.168.4.102:80 check
86
87 backend phpg
88 balance roundrobin
89 server app103 192.168.4.103:80 check
90 server app104 192.168.4.104:80 check
4、保存配置,重启服务,测试:
在四台服务器上分别放上test.html和test.php网页文件
在客户端分别测试,可以得出预期的结果