第七十七章 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) 的选项。

相关推荐
一只小bit2 小时前
Linux网络:阿里云轻量级应用服务器配置防火墙模板开放端口
linux·网络·阿里云
嘉琪0013 小时前
实现视频实时马赛克
linux·前端·javascript
帽儿山的枪手3 小时前
HVV期间,如何使用SSH隧道绕过内外网隔离限制?
linux·网络协议·安全
邹诗钰-电子信息工程4 小时前
嵌入式基础知识复习(C语言)
linux·c语言·vim
lang201509285 小时前
关于 Apache Ignite 中 Job 调度(Job Scheduling)与冲突控制(Collision Control) 的机制说明
apache·ignite
瀚高PG实验室5 小时前
CentOS 8 安装HGDB V4.5 psql命令执行报错
linux·运维·centos·瀚高数据库
小醉你真好5 小时前
6、CentOS 9 安装 Docker
linux·docker·centos
平生不喜凡桃李6 小时前
Linux 线程概念与控制
java·linux·运维
獭.獭.7 小时前
Linux -- 文件【中】
linux
无敌的牛8 小时前
Linux重定向的理解
linux·运维·服务器