马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?开始注册
x
LVS:
6 h3 |/ N. B. U1、抗负载能力强。抗负载能力强、性能高,能达到F5硬件的60%;对内存和cpu资源消耗比较低
# R* Z- g. ~: R7 s3 B2、工作在网络4层,通过vrrp协议转发(仅作分发之用),具体的流量由linux内核处理,因此没有流量的产生。; a* V R9 T9 q, l$ Q/ `- u
2、稳定性、可靠性好,自身有完美的热备方案;(如:LVS+Keepalived)" P+ S3 s* C" D) m: H. x- i! T
3、应用范围比较广,可以对所有应用做负载均衡;3 n( j t( `# h4 r
4、不支持正则处理,不能做动静分离。
r5 M: q5 O4 A/ ^5、支持负载均衡算法:rr(轮循)、wrr(带权轮循)、lc(最小连接)、wlc(权重最小连接)% @' d4 o9 J( Z- X6 B9 y+ h
6、配置 复杂,对网络依赖比较大,稳定性很高。! w& j7 m% {9 z9 e
# I n1 R& R- k, |& {$ @
+ D/ D {" i/ S2 s; TNgnix:
$ n. ~1 l" N& q) d% b1、工作在网络的7层之上,可以针对http应用做一些分流的策略,比如针对域名、目录结构;+ D: b- e) t1 M
2、Nginx对网络的依赖比较小,理论上能ping通就就能进行负载功能;& g2 Q. O+ X6 [5 `% k9 ^
3、Nginx安装和配置比较简单,测试起来比较方便;# v3 p7 ~/ n& E1 u+ J$ z$ E8 i: T
4、也可以承担高的负载压力且稳定,一般能支撑超过1万次的并发;: Y- @# v. s4 m( }/ u
5、对后端服务器的健康检查,只支持通过端口来检测,不支持通过url来检测。
3 C/ v' C9 ~1 B; W4 Q1 ]6 u6、Nginx对请求的异步处理可以帮助节点服务器减轻负载;
" I5 Y* i% P+ k' @8 Y# e. j7、Nginx仅能支持http、https和Email协议,这样就在适用范围较小。: X( g* o% p# B
8、不支持Session的直接保持,但能通过ip_hash来解决。、对Big request header的支持不是很好,
. N" @( `8 v! v/ k1 F; ]1 B9、支持负载均衡算法:Round-robin(轮循)、Weight-round-robin(带权轮循)、Ip-hash(Ip哈希)% `- |* w4 z# l4 V+ l( V3 }
10、Nginx还能做Web服务器即Cache功能。
# |0 s. G# d6 N0 O7 x
; j) X1 H% _1 {2 z Q) u/ k8 e" w7 G: Y% Q0 u8 ~, A/ k
R! F* J7 I2 ]8 X% R8 d
HAProxy的特点是:" `* V9 @# g7 N& s
1、支持两种代理模式:TCP(四层)和HTTP(七层),支持虚拟主机;' Z, Y( x- {/ n) O
2、能够补充Nginx的一些缺点比如Session的保持,Cookie的引导等工作
' t- d1 s+ U) @: C3、支持url检测后端的服务器出问题的检测会有很好的帮助。6 e7 S4 O1 E( v8 C+ g9 i9 \
4、更多的负载均衡策略比如:动态加权轮循(Dynamic Round Robin),加权源地址哈希(Weighted Source Hash),加权URL哈希和加权参数哈希(Weighted Parameter Hash)已经实现
5 U3 v- U" D4 }: T0 I5、单纯从效率上来讲HAProxy更会比Nginx有更出色的负载均衡速度。0 q9 u1 n2 z {: X# X3 `# C
6、HAProxy可以对Mysql进行负载均衡,对后端的DB节点进行检测和负载均衡。
7 p& \7 N7 h# B, E9 D0 u9、支持负载均衡算法:Round-robin(轮循)、Weight-round-robin(带权轮循)、source(原地址保持)、RI(请求URL)、rdp-cookie(根据cookie)8 \* F4 _( G! k. b7 q
10、不能做Web服务器即Cache。
6 `9 {) ~4 _' N# s" l) ~* h* p! L2 `: }$ o) F6 T
# n# |4 w5 K; T9 q$ k0 }5 _
1、网站建设初期,可以选用Nigix/HAproxy作为反向代理负载均衡(或者流量不大都可以不选用负载均衡),因为其配置简单,性能也能满足一般的业务场景。如果考虑到负载均衡器是有单点问题,可以采用Nginx+Keepalived/HAproxy+Keepalived避免负载均衡器自身的单点问题。
- b7 U( @# \9 _8 c$ |. i2、网站并发达到一定程度之后,为了提高稳定性和转发效率,可以使用LVS、毕竟LVS比Nginx/HAproxy要更稳定,转发效率也更高。不过维护LVS对维护人员的要求也会更高,投入成本也更大。% { }* u" \ z2 i( d
; Y, ^. L$ C: O注:Niginx与Haproxy比较:Niginx支持七层、用户量最大,稳定性比较可靠。Haproxy支持四层和七层,支持更多的负载均衡算法,支持session保存等。具体选型看使用场景,目前来说Haproxy由于弥补了一些Niginx的缺点用户量也不断在提升。/ J" i2 h' T8 X9 C! i' Q
8 p9 y8 K' B5 h7 t- p. R g8 b! G
2 o$ }: f# h0 D( Z8 `- l7 S1、会话率 :单位时间内的处理的请求数 : U, X, d0 [5 o2 k
2、会话并发能力:并发处理能力
& a }# [9 r4 x; x- q# i. r3、数据率:处理数据能力
( L$ G( V8 [8 J6 _9 c经过官方测试统计,haproxy 单位时间处理的最大请求数为20000个,可以同时维护40000-50000个并发连接,最大数据处理能力为10Gbps。综合上述,haproxy是性能优越的负载均衡、反向代理服务器。 u2 V- y: ]" @
& l/ v1 {: Z; U Z3 L1 a# F; V0 f( C6 R8 `% E
HAProxy主要优点: 一、免费开源,稳定性也是非常好,这个可通过我做的一些小项目可以看出来,单Haproxy也跑得不错,稳定性可以与LVS相媲美; 二、根据官方文档,HAProxy可以跑满10Gbps-New benchmark of HAProxy at 10 Gbps using Myricom's 10GbE NICs (Myri-10G PCI-Express),这个作为软件级负载均衡,也是比较惊人的; 三、HAProxy可以作为MySQL、邮件或其它的非web的负载均衡,我们常用于它作为MySQL(读)负载均衡; 四、自带强大的监控服务器状态的页面,实际环境中我们结合Nagios进行邮件或短信报警,这个也是我非常喜欢它的原因之一; 五、HAProxy支持虚拟主机。
5 d5 U) O C+ }4 q- j6 [) h% ^7 k5 D$ p$ ~: c
2 X" V3 X7 K/ U; M6 l3 i |