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

  • 相关阅读:
    一、CentOS 7安装部署GitLab服务器

    四、指定Nginx启动用户
    三、Nginx支持php
    二、Nginx多站点配置(参考宝塔的)分析
    一、Nginx多站点配置
    一、PHP和Apache实现多用户自助建站
    Flask+uwsgi+Nginx+Ubuntu部署
    flask 上传头像
    flask 分页
  • 原文地址:https://www.cnblogs.com/qwop/p/6637359.html
Copyright © 2011-2022 走看看