• Haproxy 8种算法+Session共享


    Haproxy有8种负载均衡算法(balance),分别如下:

    1.balance roundrobin # 轮询,软负载均衡基本都具备这种算法
    
    2.balance static-rr # 根据权重,建议使用
    
    3.balance leastconn # 最少连接者先处理,建议使用
    
    4.balance source # 根据请求源IP,建议使用
    
    5.balance uri # 根据请求的URI
    
    6.balance url_param,# 根据请求的URl参数'balance url_param' requires an URL parameter name
    
    7.balance hdr(name) # 根据HTTP请求头来锁定每一次HTTP请求
    
    8.balance rdp-cookie(name) # 根据据cookie(name)来锁定并哈希每一次TCP请求

    由于负载请求分发到不同服务器,可能导致Session会话不同步的问题,若想实现会话共享或保持,可采用如下3种方式:

    1.用户IP 识别

    haroxy 将用户IP经过hash计算后 指定到固定的真实服务器上(类似于nginx 的IP hash 指令)

    配置指令

    balance source

    2.Cookie 识别

    haproxy 将WEB服务端发送给客户端的cookie中插入(或添加加前缀)haproxy定义的后端的服务器COOKIE ID。

    配置指令例举

    cookie SESSION_COOKIE insert indirect nocache

    用firebug可以观察到用户的请求头的cookie里 有类似” Cookie jsessionid=0bc588656ca05ecf7588c65f9be214f5; SESSION_COOKIE=app1” SESSION_COOKIE=app1就是haproxy添加的内容

    3.Session 识别

    haproxy 将后端服务器产生的session和后端服务器标识存在haproxy中的一张表里。客户端请求时先查询这张表。

    配置指令例举

    appsession JSESSIONID len 64 timeout 5h request-learn

  • 相关阅读:
    iOSraywenderlich翻译使用MapKit叠加图层
    IOSTableView学习V2.0
    html的<input>标签常用属性
    SQLSqlServer中decimal(numeric )、float 和 real 数据类型的区别[转]
    PhoneGapV1.0
    IOSPlistV1.0
    IOS使用 UITableView 创建表格应用演练(1)——一个简单的表格应用V3.0
    IOSTableView学习V4.0
    IOS从plist文件加载并显示数据
    学习思路
  • 原文地址:https://www.cnblogs.com/qwop/p/6637359.html
Copyright © 2020-2023  润新知