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

[经验分享] Haproxy源码分析一、概述

[复制链接]

尚未签到

发表于 2015-11-20 13:36:33 | 显示全部楼层 |阅读模式
http://blog.iyunv.com/solaris_zune/article/details/8836666

在具体的分析程序源代码之前,我准备先看一下Haproxy的doc目录下的architecture.txt文件。
作者在此文件中说,由于涉及到解释性的脚本语言,一个网络应用程序的前端服务器SERVER往往都会承受非常大的压力;当然这也可能依赖于相对压力不是很大的后端的数据库服务器DB。(对于后者,我的理解是当DB慢一点的话,SERVER对于请求的响应就没那么快,新的请求又来到,又要分配新的资源,造成累积,自然也就会使SERVER的压力变大。)
对于网络服务器来说,用户的上下文也是存储在SERVER中,而不是存储在DB中,因此如果为了解决上述问题而通过简单的IP/TCP负载均衡来增加另一个SERVER的话是不能正常工作的。(因为用户相关的上下文是在SERVER中,如果后续连接通过负载均衡分配到其他机器上的话,那么将会找不到相应信息)
而将SERVER换成大型机系统的花费比增加几台便宜点的机器要高得多。对此,作者说可以买几台便宜的机器,在原来的老机器上安装Haproxy,将系统压力分散到多个机器中。也就是将架构从图(1)改成图(2)
+-------+
|clients|  clients and/or reverse-proxy
+---+---+
|
-+-----+--------+----
|       _|_db
+--+--+   (___)
| web |   (___)
+-----+   (___)
192.168.1.1   192.168.1.2

               图(1)
192.168.1.1    192.168.1.11-192.168.1.14   192.168.1.2
-------+-----------+-----+-----+-----+--------+----
        |           |     |     |     |       _|_db
     +--+--+      +-+-+ +-+-+ +-+-+ +-+-+    (___)
     | LB1 |      | A | | B | | C | | D |    (___)
     +-----+      +---+ +---+ +---+ +---+    (___)
     haproxy        4 cheap web servers

              图(2)

Haproxy数据流处理流程如下:
(client)                           (haproxy)                         (server A)
  >-- GET /URI1 HTTP/1.0 ------------> |
               ( no cookie, haproxy forwards in load-balancing mode. )
                                       | >-- GET /URI1 HTTP/1.0 ---------->
                                       | <-- HTTP/1.0 200 OK -------------<
               ( the proxy now adds the server cookie in return )
  <-- HTTP/1.0 200 OK ---------------< |
      Set-Cookie: SERVERID=A           |
  >-- GET /URI2 HTTP/1.0 ------------> |
      Cookie: SERVERID=A               |
      ( the proxy sees the cookie. it forwards to server A and deletes it )
                                       | >-- GET /URI2 HTTP/1.0 ---------->
                                       | <-- HTTP/1.0 200 OK -------------<
   ( the proxy does not add the cookie in return because the client knows it )
  <-- HTTP/1.0 200 OK ---------------< |
  >-- GET /URI3 HTTP/1.0 ------------> |
      Cookie: SERVERID=A               |
                                    ( ... )

这就是Haproxy对于http会话的保持方式。首先客户端发出第一个请求时,通过负载均衡算法找出一个SERVER对其进行处理,SERVER在处理完返回信息的时候将会在HTTP的头中增加一个Cookie,SERVERID=A。在客户端的后续请求中将会使用此Cookie来确定其对应的SERVER。由于客户端已经知道了Cookie,因此对于以后的响应数据,Haproxy不会在插入此Cookie。
对于属于KEEP-ALIVE的连接,Haproxy对Cookie不敏感,因为只要已连接之后,后续的请求肯定都是在此session上进行处理。
对于那些由于某种原因客户端只支持一个Cookie的情况下,并且应用程序返回的响应中已经设置了一个Cookie,那么可以使用前置Cookie来进行标记,也就是在响应信息返回时在Haproxy中修改Cookie增加前置信息,在接收到后续的请求时将Cookie中的前置部分清除掉在发送到SERVER。
从这儿可以看出Haproxy主要是使用Cookie来解决session的问题,那么对于不支持Cookie的浏览器怎么办?可以使用适当的负载均衡算法来解决,比如用对源IPHASH来进行负载均衡,那么可以保持同一IP总是在同一机器上。对于多IP的客户端怎么办?那就要求它使用单一IP,或则支持Cookie。
对architecture.txt就看到这儿,因为这主要是为了知道Haproxy的工作原理。
那么为什么architecture.txt只讲了HTTP层次的SESSION保持,而不讲TCP层次SESSION保持呢?从我的感觉来说,TCP层次没有所谓SESSION概念。假设某TCP层次程序的某两笔业务A和B的关系是B的处理需要A的处理结果,那么A的处理结果一般都会保存于DB中。

运维网声明 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-141526-1-1.html 上篇帖子: HAProxy 研究笔记 -- TCP 连接处理流程 下篇帖子: HAProxy Load Balancer 学习笔记
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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