云原生(基于 Cookie 的会话保持,HAProxy 状态页实验)

实验简介

该实验旨在优化 HAProxy 的负载均衡策略,实现更精细的会话保持效果:

  1. 核心目标 :默认source算法仅能让同一客户端主机(无论浏览器)固定访问某一后端服务器,而通过 Cookie 优化后,可实现同一客户端的同一浏览器绑定到特定后端服务器,不同浏览器则分配不同服务器。
  2. 配置要点 :在 HAProxy 配置文件中定义webcluster监听段,启用轮询(roundrobin)负载均衡,指定hash-type consistent,并通过cookie WEBCOOKIE insert nocache indirect插入 Cookie;为两台后端服务器(192.168.0.10/20)分别配置cookie web1/web2标识,同时设置健康检查参数(如check inter 3s)和权重。
  3. 验证效果:分别用 Firefox 和 Edge 浏览器访问,验证不同浏览器会被分配到不同的后端服务器,同一浏览器则持续访问同一服务器。

HAProxy 状态页实验

该实验聚焦于 HAProxy 自身运行状态的可视化监控配置:

  1. 核心目标:配置 HAProxy 的状态监控页面,实现对负载均衡集群的运行状态、后端服务器健康度等信息的实时查看。
  2. 基础配置 :在 HAProxy 配置文件中新增stats监听段,指定 HTTP 模式、绑定 4321 端口,启用状态统计(stats enable),设置状态页访问路径(stats uri /status),并配置认证(stats auth lee:lee),重启服务后可通过账号密码访问状态页。
  3. 进阶优化 :添加stats refresh 1配置实现状态页 1 秒自动刷新,便于实时监控;还可模拟后端设备下线,验证状态页能及时反映服务器健康状态变化。
  4. 价值:通过状态页可直观查看后端服务器的在线状态、流量分配、健康检查结果等,是运维 HAProxy 集群的重要可视化手段。

基于cookie的会话保持

复制代码
#配合基于cookie的会话保持方法
[root@haproxy yxs]# vim /etc/haproxy/haproxy.cfg
listen webcluster
    bind        *:80
    balance     roundrobin
    hash-type   consistent
    cookie WEBCOOKIE insert nocache indirect
    server haha 192.168.0.10:80 cookie web1 check inter 3s fall 3 rise 5 weight 2
    server hehe 192.168.0.20:80 cookie web2 check inter 3s fall 3 rise 5 weight 1
[root@haproxy yxs]# systemctl restart haproxy.service

测试

edge

chrome

HAProxy状态页

复制代码
[root@haproxy yxs]# vim /etc/haproxy/haproxy.cfg
listen stats
    mode        http
    bind 0.0.0.0:4321
    stats       enable
    log         global
#   stats       refresh
    stats uri   /status
    stats auth  lee:lee
[root@haproxy yxs]# systemctl restart haproxy.service

登录测试

开启自动刷新

复制代码
[root@haproxy yxs]# vim /etc/haproxy/haproxy.cfg
listen stats
    mode        http
    bind 0.0.0.0:4321
    stats       enable
    log         global
    stats       refresh   1
    stats uri   /status
    stats auth  lee:lee
[root@haproxy yxs]# systemctl restart haproxy.service

模拟设备下线

复制代码
[root@webserver1 yxs]# systemctl stop httpd.service 
相关推荐
秋播2 天前
国内本地WSL2编译rancher源码
云原生
小猿姐3 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
阿里云云原生4 天前
深入内核:拆解 OpenTelemetry eBPF 探针如何优雅地“透视”多语言微服务?
云原生
java_cj4 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes
互联网推荐官5 天前
上海软件定制开发公司推荐:从PaaS工程化路径看D-coding的技术取舍
云原生·云计算·paas·软件开发·开发经验·上海
sbjdhjd5 天前
从零搭建企业级 CI/CD(下):Jenkins+GitLab+Harbor 全链路实战指南
git·servlet·ci/cd·云原生·云计算·gitlab·jenkins
java_cj5 天前
深入kubectl create源码:从YAML到Pod的完整链路拆解
运维·云原生·容器·kubernetes
步步为营DotNet5 天前
基于.NET Aspire 实现云原生应用的高效监控与可观测性
云原生·.net·wpf
牛奶咖啡135 天前
KVM虚拟化与企业应用实践——给远端主机创建虚拟机
云原生·qemu·kvm·给远端主机创建虚拟机·创建uefi模式的虚拟机·安装openeulersp2·vnc与虚拟机环境搭建
java_cj5 天前
从kubectl学Visitor模式:如何优雅处理多态数据结构的遍历
云原生·golang·k8s·访问者模式