2024年6月11日发(作者:)

1.什么是会话保持?

在大多数电子商务的应用系统或者需要进行用户身份认证的在线系统中,一个客户与服务

器经常经过好几次的交互过程才能完成一笔交易或者是一个请求的完成.由于这几次交互过

程是密切相关的,服务器在进行这些交互过程的某一个交互步骤时,往往需要了解上一次

交互过程的处理结果,或者上几步的交互过程结果,服务器进行下一步操作时就要求所有

这些相关的交互过程都由一台服务器完成,而不能被负载均衡器分散到不同的服务器上。

而这一系列的相关的交互过程可能是由客户到服务器的一个连接的多次会话完成,也可

能是在客户与服务器之间的多个不同连接里的多次会话完成。不同连接的多次会话,最典

型的例子就是基于http的访问,一个客户完成一笔交易可能需多次点击,而一个新的点击产

生的请求,可能会重用上一次点击建立起来的连接,也可能是一个新建的连接。

会话保持就是指在负载均衡器上有这么一种机制,可以识别做客户与服务器之间交互过

程的关连性,在作负载均衡的同时,还保证一系列相关连的访问请求会保持分配到一台服

务器上.

2.F5支持什么样的会话保持方法?

F5 Big-IP支持多种的会话保持方法,其中包括:简单会话保持(源地址会话保持)、

HTTP Header的会话保持,基于SSL Session ID的会话保持,i—Rules会话保持以及基

于HTTP Cookie的会话保持,此外还有基于SIP ID以及Cache设备的会话保持等,但常用

的是简单会话保持,HTTP Header的会话保持以及 HTTP Cookie会话保持以及基于i-

Rules的会话保持。

2。1 简单会话保持

简单会话保持也被称为基于源地址的会话保持,是指负载均衡器在作负载均衡时是根据

访问请求的源地址作为判断关连会话的依据。对来自同一IP地址的所有访问 请求在作负

载均时都会被保持到一台服务器上去。在BIG—IP设备上可以为“同一IP地址”通过网络掩

码进行区分,比如可以通过对IP地址 192。168。1。1进行255.255.255.0的网络掩码,

这样只要是来自于192。168。1。0/24这个网段的流量BIGIP都可以认为他们是来自于同

一个用户,这样就将把来自于192.168。1.0/24网段的流量会话保持到特定的一台服务器

上。

简单会话保持里另外一个很重要的参数就是连接超时值,BIGIP会为每一个进行会话保

持的会话设定一个时间值,当一个会话上一次完成到这个会话下次再来之前的间隔如果小

于这个超时值,BIGIP将会将新的连接进行会话保持,但如果这个间隔大于该超时值,BIGIP

将会将新来的连接认为是新的会话然后进行负载平衡。

基于原地址的会话保持实现起来简单,只需要根据数据包三、四层的信息就可以实现,

效率也比较高。存在的问题就在于当多个客户是通过代理或地址转换的方式来访问服务器

时,由于都分配到同一台服务器上,会导致服务器之间的负载严重失衡.另外一种情况上客

户机数量很少,但每个客户机都会产生多个并发访问,对这些并发访问也要求通过负载均衡

器分配到多个服器上,这时基于客户端源地址的会话保持方法也会导致负载均衡失效。

2.2 基于Cookie的会话保持

2。2.1 Cookie插入模式:

在Cookie插入模式下,Big-IP将负责插入cookie,后端服务器无需作出任何修改

当客户进行第一次请求时,客户HTTP请求(不带cookie)进入BIG-IP, BIG—IP根据负

载平衡算法策略选择后端一台服务器,并将请求发送至该服务器,后端服务器进行HTTP回

复(不带cookie)被发回BIGIP,然后 BIG—IP插入cookie,将HTTP回复返回到客户端.当

客户请求再次发生时,客户HTTP请求(带有上次BIGIP插入的cookie)进入 BIGIP,然

后BIGIP读出cookie里的会话保持数值,将HTTP请求(带有与上面同样的cookie)发到

指定的服务器,然后后端服务器进行请求回复,由于服务器并不写入cookie,HTTP回复

将不带有cookie,恢复流量再次经过进入BIG—IP时,BIG-IP再次写入更新后的会话保持

cookie。

2。2。2 Cookie 重写模式

当客户进行第一次请求时,客户HTTP请求(不带cookie)进入BIGIP, BIGIP根据负

载均衡算法策略选择后端一台服务器,并将请求发送至该服务器,后端服务器进行HTTP回

复一个空白的cookie并发回BIGIP,然后BIGIP重新在cookie里写入会话保持数值,将

HTTP回复返回到客户端。当客户请求再次发生时,客户HTTP请求(带有上次BIGIP重写

的 cookie)进入BIGIP,然后BIGIP读出cookie里的会话保持数值,将HTTP请求(带

有与上面同样的cookie)发到指定的服务器,然后后端服务器进行请求回复,HTTP回复里

又将带有空的cookie,恢复流量再次经过进入BIGIP时,BIGIP再次写入更新后会话保持

数值到该 cookie。

2。2。3 Passive Cookie 模式,服务器使用特定信息来设置cookie。

当客户进行第一次请求时,客户HTTP请求(不带cookie)进入BIGIP, BIGIP根据负

载平衡算法策略选择后端一台服务器,并将请求发送至该服务器,后端服务器进行HTTP回

复一个cookie并发回BIGIP,然后 BIGIP将带有服务器写的cookie值的HTTP回复返回到

客户端。当客户请求再次发生时,客户HTTP请求(带有上次服务器写的cookie)进入

BIGIP,然后BIGIP根据cookie里的会话保持数值,将HTTP请求(带有与上面同样的

cookie)发到指定的服务器,然后后端服务器进行请 求回复,HTTP回复里又将带有更新的

会话保持cookie,恢复流量再次经过进入BIGIP时,BIGIP将带有该cookie的请求回复给

客户端.

2。2.4 Cookie Hash模式:

当客户进行第一次请求时,客户HTTP请求(不带cookie)进入BIGIP, BIGIP根据负载

均衡算法策略选择后端一台服务器,并将请求发送至该服务器,后端服务器进行HTTP回

复一个cookie并发回BIGIP,然后 BIGIP将带有服务器写的cookie值的HTTP回复返回到

客户端。当客户请求再次发生时,客户HTTP请求(带有上次服务器写的cookie)进入

BIGIP,然后BIGIP根据cookie里的一定的某个字节的字节数来决定后台服务器接受请求,

将HTTP请求(带有与上面同样的cookie)发到指定的服务器,然后后端服务器进行请求

回复,HTTP回复里又将带有更新后的cookie,恢复流量再次经过进入BIGIP时,BIGIP

将带有该 cookie的请求回复给客户端.

2.3 SSL Session ID会话保持

在用户的SSL访问系统的环境里,当SSL对话首次建立时,用户与服务器进行首次信息

交换以:1}交换安全证书,2)商议加密和压缩方法,3)为每条对话 建立Session ID.由于该

Session ID在系统中是一个唯一数值,由此,BIGIP可以应用该数值来进行会话保持.当用

户想与该服务器再次建立连接时,BIGIP可以通过会话中的 SSL Session ID识别该用户并

进行会话保持。

基于SSL Session ID的会话保持就需要客户浏览器在进行会话的过程中始终保持其

SSL Session ID不变,但实际上,微软Internet Explorer被发现在经过特定一段时间后将