博客
关于我
httpd源阅读分析1--从main开始
阅读量:722 次
发布时间:2019-03-21

本文共 1345 字,大约阅读时间需要 4 分钟。

Apache 2.4.10的prefork MPM实现细节

Apache服务器的分布式版本控制模块(MPM,Multiprocessing Module)决定了服务器如何处理和管理请求。对于prefork MPM而言,Apache会根据配置创建多个子进程来处理请求。深入了解prefork MPM的实现,可以帮助我们更好地优化服务器性能和资源使用。

prefork_pre_config函数解析

prefork预先配置阶段是prefork MPM启动时的关键步骤。在这个阶段,服务器会设置一些必要的参数以确保MPM正常运行。关键步骤如下:

  • 参数初始化:设定no_detachdebugforeground变量。这些变量对应了Apache的配置选项NO_DETACHDEBUGFOREGROUND。如果DEBUG选项被启用,foregroundone_process都会被设置为1,这意味着服务器将运行在前台模式。

  • 用户数据处理:通过userdata_key获取或创建一个用户数据结构。这个结构存储了进程管理的相关信息,如最大允许的子进程数量等。

  • 信号处理:当mulitple进程被成功创建并加载必要的模块后,服务器会设置有针对性的信号处理,以确保在退出时对错误日志进行正确的记录和处理。

  • 默认参数设置:初始化父进程ID和默认的子进程数。默认情况下,prefork会启动2个子进程,这可以根据服务器需求进行调整。

  • 预配置执行:启动默认配置,并设置一些默认参数以确保服务器能够顺利运行。

  • 调用链与实现

    prefork_pre_config函数主要是在初始配置阶段被调用。具体来说,它在prefork_run函数中被调用。prefork_run函数又根据服务器配置动态地计算出最大可以拥有的子进程数。这种动态计算确保了服务器在高负载情况下能够灵活调整资源分配。

    关键函数分析

  • prefork_cmds:处理命令行参数,特别是StartServers指令。它确保服务器根据配置文件中的设置创建合适数量的子进程。

  • prefork_run:执行prefork模块的核心逻辑。在初始配置阶段,这个函数会根据MaxRequestWorkersMaxClients设置来确定最大子进程数。

  • 实施带来的影响

    prefork预先配置阶段的正确执行直接影响到服务器性能和稳定性:

    • 如果在配置中设置了NO_DETACH,服务器将运行在前台模式。这样可以方便用户观察运行状态。

    • DEBUG选项启用会生成更详细的日志信息,这对于调试和监控服务器运行状态非常有用。

    • FOREGROUND选项允许服务器以前台模式运行,即使在daemonize之后,它也会继续在前台显示状态。这对于开发和调试阶段尤其有用。

    总结

    prefork预先配置阶段是prefork MPM的关键部分。通过正确理解并应用prefork_pre_config函数和相关调用链,我们可以充分掌握prefork MPM的工作机制,并根据实际需求优化服务器配置。例如,在高并发场景下,可以适当调高MaxClientsMaxRequestWorkers,以支持更多的并发连接。同时,可以通过监控日志来跟踪prefork模块的运行状态,确保其稳定性。

    转载地址:http://ojwrz.baihongyu.com/

    你可能感兴趣的文章
    MYSQL 主从同步文档的大坑
    查看>>
    mysql 主键重复则覆盖_数据库主键不能重复
    查看>>
    Mysql 事务知识点与优化建议
    查看>>
    Mysql 优化 or
    查看>>
    mysql 优化器 key_mysql – 选择*和查询优化器
    查看>>
    MySQL 优化:Explain 执行计划详解
    查看>>
    Mysql 会导致锁表的语法
    查看>>
    mysql 使用sql文件恢复数据库
    查看>>
    mysql 修改默认字符集为utf8
    查看>>
    Mysql 共享锁
    查看>>
    MySQL 内核深度优化
    查看>>
    mysql 内连接、自然连接、外连接的区别
    查看>>
    mysql 写入慢优化
    查看>>
    mysql 分组统计SQL语句
    查看>>
    Mysql 分页
    查看>>
    Mysql 分页语句 Limit原理
    查看>>
    MySql 创建函数 Error Code : 1418
    查看>>
    MySQL 创建新用户及授予权限的完整流程
    查看>>
    mysql 创建表,不能包含关键字values 以及 表id自增问题
    查看>>
    mysql 删除日志文件详解
    查看>>