你真的了解 apache httpd 得多路复用吗

原创:花括号MC(微信公众号:huakuohao-mc)。关注JAVA基础编程及大数据,注重经验分享及我的成长。nginx

目前的web服务器,apachehttpdnginx能够说是绝代双骄,一个是江湖老大哥,一个是后起之秀。虽然如今你们的首选是nginx,不少项目由于各类缘由仍是会选择使用apachehttpd做为web服务器。web

随着最新版httpd 2.4的发布,event模块也变成了稳定版本,与nginx的性能差距再次缩小。apache

Apache httpd 服务器有三种MPM(多路处理模块),分别是prefork,workerevent。这三种模块性格迥异,不一样的模块对httpd的性能及使用场景会产生比较大的影响。编程

查看httpd服务器使用的哪一个模块能够经过以下指令 httpd -l。从输出能够看出使用得是worker模式。安全

Compiled in modules:
    core.c
    mod_so.c
    http_core.c
    worker.c
复制代码
MPM介绍
prefork

进程模式。每一个请求都由一个子进程来处理。线程安全。不太适合高并发服务器。bash

  • 工做原理如图:

worker

进程线程混合模式。父进程会建立子进程,每一个子进程会建立多个工做线程以及一个监听线程。每个线程负责处理一个http请求。服务器

  • 工做原理,如图:

event

进程线程混合模式。跟worker模式很像,不一样的是采用epoll模式,在2.4以前的版本是实验版本,如今已经稳定了。性能比worker要好不少。并在keepalive方面作了优化。微信

  • 工做原理 与worker基本相同,这里就不放图了。

这三种模式,在启动的时候都会启动固定数量的子进程。同时三种模式都会建立必定数量的空闲子进程,以便新的请求进来时,能够直接使用。网络

通用配置

三种模式都有一些通用的参数指令,个别指令在不一样模式下面含义有些许不一样:并发

StartServers :服务器启动时创建的子进程数。

MinSpareServers:空闲子进程的最小数量。当空闲子进程小于这个值时,父进程将会建立子进程。

MaxSpareServers:空闲子进程的最大数量。当空闲子进程大于这个值时,父进程会杀死多余的子进程。

MaxRequestWorkders:容许同时接受的最大接入请求数量;若是提高该值,也须要同时提升ServerLimit。任何超过了该值的请求数都要进入等待队列。在以前的版本被称为MaxClients。如今的版本也支持该参数。

注意: 在workerevent 模式下MaxRequestWorks = ServerLimit * ThreadsPerChild

ListenBacklog :半连接(pending connection)队列的最大长度。

ServerLimit: 服务器容许配置的进程数上限。

MaxConnectionsPerChild:每一个子进程在其生命周期内容许最大的请求数量,若是请求总数已经达到这个数值,子进程将会结束,若是设置为0,子进程将永远不会结束。在以前的版本称之为MaxRequestsPerChild

建议设置为非零,缘由:

  1. 可以防止(偶然的)内存泄漏无限进行,从而耗尽内存。
  2. 给进程一个有限寿命,从而有助于当服务器负载减轻的时候减小活动进程的数量(重生的机会)。

配置样例 prefork模式

<IfModule prefork.c>
    StartServers      5
    MinSpareServers   10
    MaxSpareServers   20
    ServerLimit      1024
    MaxRequestWorkders  1024
    MaxRequestsPerChild  160
</IfModule>
复制代码
worker 与 event 特有的配置参数

ThreadsPerChild:每一个子进程,产生多少线程。不能超过ThreadLimit 。

ThreadLimit:每一个子进程可配置的线程数。

AsyncRequestWorkerFactor:该参数event模式独有。默认值为2。可设置为小数,例如1.5。

该参数用来调整每一个进程容许的链接数。只有当前链接数(不包括正处于closing状态的链接)小于下面的表达式的值时,子进程才容许接收新链接。最好不要调整该值,除非你通过大量测试。 ThreadsPerChild +(AsyncRequestWorkerFactor * number of idle workers)

配置样例 worker模式

<IfModule worker.c>
    StartServers        5
    ServerLimit         40
    MaxRequestWorkders  2560
    MinSpareThreads     10
    MaxSpareThreads     20
    ThreadsPerChild     64
    MaxRequestsPerChild  160
</IfModule>
复制代码
web服务器经常使用运维指令

我把我经常使用得一些网络运维脚本送给各位吧,有凑字数嫌疑(偷笑)。

查看状态为established 的TCP链接:netstat -na|grep ESTABLISHED|wc -l

统计哪一个IP地址链接最多: netstat -na|grep ESTABLISHED|awk '{print $5}'|awk -F: '{print $1}'|sort|uniq -c|sort -r

统计TCP链接状态: netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'

结束

关于apache httpd 的配置及MPM简介,上面的内容基本就说完了。稍微了解TCP及网络编程知识的同窗可能会好奇,TCP链接对外提供服务的是一个固定端口,好比httpd默认是80端口,那apache httpd是如何作到同时支持多个请求的呢,也就是高并发。还有worker模式和event模式都是进程线程混合模式,为何event模式就比worker模式优秀呢,也就是你们常常开玩笑说的,一样是九年义务教育你为何如此优秀。我将在下篇文章中给你们详细说一说,下一篇文章才是硬核干货知识。

·END·
 

花括号MC

Java·大数据·我的成长

微信号:huakuohao-mc
相关文章
相关标签/搜索