ALB配置会话保持

部分应用业务场景下需要保持用户会话的状态,例如购物车中的商品、登录信息、用户偏好设置、游戏应用等场景,如果用户的请求被分发到不同的服务器,那么会话状态就会丢失从而导致用户体验问题。当您开启了ALB会话保持功能后,可以使来自同一客户端的请求被转发到同一台后端服务器上,从而确保用户的体验和数据的一致性。

背景信息

默认情况下,ALB会将每个客户端请求分别分发至不同的后端服务器上。当您开启了会话保持功能后,会话保持可以使来自同一客户端的请求被转发至同一台后端服务器上,方便后端服务器维护状态信息及向客户端提供持续体验。

  • 未开启会话保持:同一客户端的请求通过ALB可能会被分发至不同的后端服务器,在某些场景下,如登录后端服务器获取交互信息等场景,客户端的请求可能需重新登录后端服务器。

  • 开启会话保持:同一客户端的请求通过ALB被分配至同一台后端服务器,而非分配至不同的后端服务器,在某些场景下,如登录后端服务器获取交互信息等场景,避免了客户端的请求需要重新登录后端服务器。

ALB开启会话保持后,需要选择Cookie的处理方式,有植入Cookie和重写Cookie两种处理方式。

  • 植入Cookie:客户端第一次访问时,ALB会在返回请求中植入Cookie(即ALB插入SERVERIDSERVERCORSID两个cookie;SERVERCORSID是以SERVERID为基础,且加入了samesite=None这个属性),下次客户端携带此Cookie访问,负载均衡服务会将请求定向转发给之前记录到的后端服务器上。

    说明

    会话保持植入Cookie方式自带SameSite=None,无需用户配置,可以有效解决ALB转发规则中跨域(CORS)场景下浏览器无法保存Cookie的问题。

  • 重写Cookie:当ALB发现用户自定义了Cookie,将会对原来的Cookie进行重写,下次客户端携带新的Cookie访问,ALB会将请求定向转发给之前记录的后端服务器。

使用限制

服务器组类型为函数计算类型时,您无需配置会话保持。更多操作,请参见创建服务器组

前提条件

  • 您已经创建了一个处于运行中状态的公网ALB实例。具体操作,请参见创建应用型负载均衡

  • 您已经创建了服务器类型或IP类型的服务器组。具体操作,请参见创建服务器组

  • 您已经创建了后端服务器ECS01ECS02,用于接收请求。ECS01ECS02中部署了不同的后端服务,访问时需要有不同展示,例如访问ECS01时返回"Hello World ! This is ECS01.",返回ECS02时返回"Hello World ! This is ECS02."。注意安全组需要对相应服务端口放行。

  • 您已将后端服务器ECS01ECS02添加到服务器组中。具体操作,请参见添加后端服务器

  • 您已经为该实例配置了监听。具体操作,请参见添加HTTP监听添加HTTPS监听添加QUIC监听

步骤一:ALB配置会话保持

  1. 登录应用型负载均衡ALB控制台

  2. 在顶部菜单栏处,选择后端服务器组所属的地域。

  3. 在左侧导航栏,选择应用型负载均衡ALB > 服务器组

  4. 服务器组页面,找到目标服务器组,在操作列单击编辑基本信息

  5. 编辑基本信息对话框中,开启会话保持。

    开启会话保持:打开开启会话保持开关并选择Cookie处理方式

    • 选择植入Cookie,输入会话保持超时时间,然后单击保存

    • 选择重写Cookie,输入Cookie名称,然后单击保存

      本文示例将Cookie名称设置为BACKEND_SERVER,该名称仅为示例,您可以自定义该名称。

(可选)步骤二:后端服务器配置Cookie

当服务器组开启会话保持,并且选择的Cookie处理方式为重写Cookie时,才需要在后端服务器中配置对应的Cookie。

  1. 远程登录ECS。具体操作,请参见ECS远程连接操作指南

  2. 根据不同的Web服务器配置Cookie。

    说明

    不同的Web服务器对应的Cookie设置方法不同,以下列举常见Web服务器的设置方法,请您根据实际情况选择,如果您使用的Web服务器不在以下列表中,请您查阅对应的官方文档获取配置方法。

    Nginx

    此处以CentOS 7.9操作系统、Nginx 1.20.1 版本配置为例介绍。具体请以您实际使用的环境为准。

    1. 修改Nginx服务配置文件并保存,修改点可参考下方说明。执行nginx -t命令查看配置文件所在路径,默认通常为/etc/nginx/nginx.conf,具体请以实际环境为准。

      http {
        # ...
        server {
          listen       80;
          # BACKEND_SERVER是您配置重写Cookie时输入的Cookie名称;value您可使用自定义字符串。
          add_header Set-Cookie "BACKEND_SERVER=value";
          # ...
        }
      }
      
    2. 执行以下命令重新加载Nginx的配置文件。

      sudo nginx -s reload

    Apache

    此处以CentOS 7.9操作系统、Apache 2.4.6版本配置为例介绍。具体请以您实际使用的环境为准。

    1. 修改Apache服务配置文件并保存,修改点可参考下方说明。默认通常为/etc/httpd/conf/httpd.conf,具体请以实际环境为准。

      # ...
      Listen 80
      # BACKEND_SERVER是您配置重写Cookie时输入的Cookie名称;value您可使用自定义字符串。
      Header always set Set-Cookie "BACKEND_SERVER=value"
      # ...
    2. 执行以下命令,重新加载Apache的配置文件,使以上改动生效。

       sudo systemctl reload httpd.service
  3. 参考以上步骤,修改服务器组中其余后端服务器的配置。

步骤三:测试会话保持的有效性

  1. 登录应用型负载均衡ALB控制台

  2. 在顶部菜单栏选择地域。找到目标ALB实例,复制其对应的DNS名称。

  3. 在浏览器中输入DNS名称,可访问某个服务器,多次刷新页面仍然访问相同服务器。

    例如您第一次访问的是ECS01,则后续几次刷新后均是访问ECS01。

    ECS01验证结果

    如果多次刷新页面后在ECS01ECS02之间切换,则会话保持配置不生效,请您检查配置是否有误再重新测试。

相关文档