第七十七章 Apache 注意事项 (UNIX® Linux macOS) - 状态感知会话(保留模式 1)

文章目录

  • [第七十七章 Apache 注意事项 (UNIX® Linux macOS) - 状态感知会话(保留模式 1)](#第七十七章 Apache 注意事项 (UNIX® Linux macOS) - 状态感知会话(保留模式 1))

第七十七章 Apache 注意事项 (UNIX® Linux macOS) - 状态感知会话(保留模式 1)

在多个工作进程之间分配负载的 Web 服务器中对状态感知会话的支持依赖于进程间通信 (IPC) 协议来管理各个工作进程之间的请求路由。在此 Web 服务器体系结构中运行时,Web 网关无法控制哪个工作进程处理任何特定请求。

Web 网关使用 UNIX® 域套接字作为其 IPC 协议,下面描述了支持状态感知会话的方法。

例如,考虑一个 Web 服务器安装,将其负载分布在 3 个工作进程上:P1P2P3。每个工作进程可以根据 Web 服务器 MPM 和使用的配置启动任意数量的线程(T1、T2 ... Tn)。

假设应用程序请求将其会话标记为状态感知(保留模式 1),并且 Web 网关在进程 P2 中确认此指令。现在私有 IRIS 进程的连接和(安全上下文)由 Web 服务器工作进程 P2 托管。该用户/会话的所有进一步请求现在必须由工作进程 P2 处理。但是,Web 网关无法控制 Web 服务器将后续请求路由到哪个工作进程,因此 Web 网关必须在 P2 和(可能)集中的任何其他工作进程之间建立 IPC 通道。

Web GatewayP2 中将连接标记为状态感知时,它会在单独的分离线程中启动侦听服务。对于日志级别 v2,事件日志中将写入类似于下图所示的消息。

java 复制代码
IPC Server 
Process ID: 28457 Listening on Domain Socket: /tmp/csp28457.str

现在,假设工作进程 P3 处理对同一会话的进一步请求。 Web 网关通过先前建立的 IPC 通道将该请求转发到处理 P2,并等待响应。对于日志级别 v2,会记录类似于以下所示的消息:

java 复制代码
Route request over IPC to another web server process
PrivateSession=2; pid_self=28456; ipc_to_pid=28457; 

当然,如果会话请求恰好由 Web 服务器直接路由到 P2,则在 Web 网关环境中不需要进一步路由,因为 P2 托管会话的专用连接。

如果 Web 网关无法连接并将请求转发到先前创建的 IPC 通道,则会根据引发错误的上下文记录以下消息之一:

java 复制代码
IPC CLIENT: Error
Cannot connect
java 复制代码
IPC CLIENT: Error
Cannot send request

该领域出现问题的最常见原因是 Apache 是否关闭(或回收)了工作进程(在本例中为 P2)。当然,进程可能会崩溃(例如,出现访问冲突/SIGSEGV 错误),在这种情况下,Apache 错误日志中可能会报告错误消息。

默认情况下,Apache 还会定期回收工作进程。

如果使用状态感知会话,请按如下方式配置安装来配置 Apache,使其不会回收工作进程。

  • MaxConnectionsPerChild 的值设置为零
  • MaxSpareThreads 的值设置为与 MaxRequestWorkers 相同的值

如果无法阻止 Apache 定期回收进程(可能是由于模块故障)并且必须使用状态感知会话,则可以使用基于 NSD 的网关配置。基于 NSD 的架构避免了上述问题,因为它有效地将 Web 网关的进程管理与 Web 服务器分开。在 Microsoft Windows 上使用 NSD 和在 UNIX®LinuxmacOS 上使用 NSD 介绍了使用 Web Gateway 网络服务守护程序 (NSD) 的选项。

相关推荐
JiMoKuangXiangQu6 小时前
ARM64 进程虚拟地址空间布局
linux·arm64 虚拟地址布局
阳光九叶草LXGZXJ6 小时前
达梦数据库-学习-47-DmDrs控制台命令(LSN、启停、装载)
linux·运维·数据库·sql·学习
春日见7 小时前
如何避免代码冲突,拉取分支
linux·人工智能·算法·机器学习·自动驾驶
无垠的广袤7 小时前
【VisionFive 2 Lite 单板计算机】边缘AI视觉应用部署:缺陷检测
linux·人工智能·python·opencv·开发板
阿波罗尼亚7 小时前
Kubectl 命令记录
linux·运维·服务器
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.8 小时前
Keepalived单播模式配置与实战指南
linux·服务器·负载均衡
IDC02_FEIYA8 小时前
Linux文件搜索命令有哪些?Linux常用命令之文件搜索命令find详解
linux·运维·服务器
江畔何人初8 小时前
kubectl apply与kubectl create的区别
linux·运维·云原生
M158227690558 小时前
四通道全能组网!SG-Canet-410 CAN转以太网网关,破解工业CAN通信瓶颈
linux·运维·服务器
誰能久伴不乏8 小时前
【Qt实战】工业级多线程串口通信:从底层协议设计到完美收发闭环
linux·c++·qt