zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    从统计学statistics的观点看概率分布
    JavaScript中getBoundingClientRect()方法详解
    insertRule()与addRule()创建规则
    Canvas 数学、物理、动画学习笔记一
    【超级干货】手机移动端WEB资源整合:转载
    JavaScript性能优化技巧之函数节流
    @font-face的用法
    Modernizr——为HTML5和CSS3而生!
    url、href、src 详解
    认识cookie与session的区别与应用
  • 原文地址:https://www.cnblogs.com/qwop/p/6637359.html
Copyright © 2011-2022 走看看