cookie value:为当前server指定cookie值,实现基于cookie的会话黏性
COOKIE 语法
cookie <name> [ rewrite | insert | prefix ] [ indirect ] [ nocache ]
[ postonly ] [ preserve ] [ httponly ] [ secure ]
[ domain <domain> ]* [ maxidle <idle> ] [ maxlife <life> ]
[ dynamic ] [ attr <value> ]*
name:cookie 的key名称,用于实现持久连接
insert:如果没有就插入新的cookie
indirect:不会向客户端发送服务器已经处理过请求的cookie信息
nocache:当client和hapoxy之间有缓存时,不缓存cookie
COOKIE 的作用域
defaults | frontend | listen | backend |
---|---|---|---|
yes | no | yes | yes |
COOKIE 配置示例
listen web_host
bind 192.168.1.101:80
mode http
log global
balance roundrobin
cookie SERVER-COOKIE insert indirect nocache
server web1 192.168.1.103:80 cookie web1 check inter 3000 fall 3 rise 5
server web2 192.168.1.104:80 cookie web2 check inter 3000 fall 3 rise 5
验证COOKIE信息
server:用来定义多台后端真实服务器,不能用于defaults和frontend部分,格式为:server name address:port param*
name:为后端真实服务器指定一个内部名称,随便这下义一个即可。
address:后端真实服务器的iP地址或主机名。
port:指定连接请求发往真实服务器时的目标端口,在未设定时,将使用客户端请求时的同一端口。
param*:为后端服务器设定的一系列参数,可用参数非常多。
check:表示启用对此后端服务器执行健康检查。
inter:设置健康状态检查的时间间隔,单位为毫秒。
rise:设置人故障状态转换至正常状态需要成功检查的次数,如 rise 2:表示2次检查正确就认为此服务器可用。
fall:设置后端服务器从正常状态转换为不可用状态需要检查的次数,如 fall 3表示3 次检查失败就认为此服务器不可用。
cookie:为指定的后端服务器设定cookie值,此外指定的值将在请求入站时被检查,第一次为此值挑选的后端服务器将在后续的请求中一直被选中,其目的在于实现持久连接的功能。
cookie server1:表示web1的serverid为server1。
weigth:设置后端真实服务器的权重,默认为1,最大值为256,设置为0表示不参与负载均衡。
maxconn:设定每个backend中server进程可接受的最大并发连接数,此选项等同于linux命令选项”ulimit -n”。
backup:设置后端真实服务器的备份服器,仅仅在后端所有真实服务器均不可用的情况下才启用。
通过命令验证
root@z5:~# curl 192.168.1.101 --cookie "SERVER-COOKIE=web1"
103 index
root@z5:~# curl 192.168.1.101 --cookie "SERVER-COOKIE=web2"
104 index
–cookie “SERVER-COOKIE=web2”
104 index