你真的了解 apache httpd 得多路复用吗
off999 2025-03-26 15:52 43 浏览 0 评论
目前的web服务器,apache的httpd与nginx可以说是绝代双骄,一个是江湖老大哥,一个是后起之秀。虽然现在大家的首选是nginx,很多项目因为各种原因还是会选择使用apache的httpd作为web服务器。
随着最新版httpd 2.4的发布,event模块也变成了稳定版本,与nginx的性能差距再次缩小。
Apache httpd 服务器有三种MPM(多路处理模块),分别是prefork,worker及event。这三种模块性格迥异,不同的模块对httpd的性能及使用场景会产生比较大的影响。
查看httpd服务器使用的哪个模块可以通过如下指令 httpd -l。从输出可以看出使用的是worker模式。
Compiled in modules:
core.c
mod_so.c
http_core.c
worker.c
MPM介绍
prefork
进程模式。每个请求都由一个子进程来处理。线程安全。不太适合高并发服务器。
- 工作原理如图:
worker
进程线程混合模式。父进程会创建子进程,每个子进程会创建多个工作线程以及一个监听线程。每一个线程负责处理一个http请求。
- 工作原理,如图:
event
进程线程混合模式。跟worker模式很像,不同的是采用epoll模式,在2.4之前的版本是实验版本,现在已经稳定了。性能比worker要好很多。并在keepalive方面做了优化。
- 工作原理 与worker基本相同,这里就不放图了。
这三种模式,在启动的时候都会启动固定数量的子进程。同时三种模式都会创建一定数量的空闲子进程,以便新的请求进来时,可以直接使用。
通用配置
三种模式都有一些通用的参数指令,个别指令在不同模式下面含义有些许不同:
StartServers :服务器启动时建立的子进程数。
MinSpareServers:空闲子进程的最小数量。当空闲子进程小于这个值时,父进程将会创建子进程。
MaxSpareServers:空闲子进程的最大数量。当空闲子进程大于这个值时,父进程会杀死多余的子进程。
MaxRequestWorkders:允许同时接受的最大接入请求数量;如果提升该值,也需要同时提高ServerLimit。任何超过了该值的请求数都要进入等待队列。在之前的版本被称为MaxClients。现在的版本也支持该参数。
注意: 在worker 和 event 模式下MaxRequestWorks = ServerLimit * ThreadsPerChild
ListenBacklog :半链接(pending connection)队列的最大长度。
ServerLimit: 服务器允许配置的进程数上限。
MaxConnectionsPerChild:每个子进程在其生命周期内允许最大的请求数量,如果请求总数已经达到这个数值,子进程将会结束,如果设置为0,子进程将永远不会结束。在之前的版本称之为MaxRequestsPerChild。
建议设置为非零,原因:
- 能够防止(偶然的)内存泄漏无限进行,从而耗尽内存。
- 给进程一个有限寿命,从而有助于当服务器负载减轻的时候减少活动进程的数量(重生的机会)。
配置样例 prefork模式
StartServers 5
MinSpareServers 10
MaxSpareServers 20
ServerLimit 1024
MaxRequestWorkders 1024
MaxRequestsPerChild 160
worker 与 event 特有的配置参数
ThreadsPerChild:每个子进程,产生多少线程。不能超过ThreadLimit 。
ThreadLimit:每个子进程可配置的线程数。
AsyncRequestWorkerFactor:该参数event模式独有。默认值为2。可设置为小数,例如1.5。
该参数用来调整每个进程允许的连接数。只有当前连接数(不包括正处于closing状态的连接)小于下面的表达式的值时,子进程才允许接收新连接。最好不要调整该值,除非你经过大量测试。 ThreadsPerChild +(AsyncRequestWorkerFactor * number of idle workers)
配置样例 worker模式
StartServers 5
ServerLimit 40
MaxRequestWorkders 2560
MinSpareThreads 10
MaxSpareThreads 20
ThreadsPerChild 64
MaxRequestsPerChild 160
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模式优秀呢,也就是大家经常开玩笑说的,同样是九年义务教育你为什么如此优秀。我将在下篇文章中给大家详细说一说,下一篇文章才是硬核干货知识。
相关推荐
- linux软件(linux软件图标)
-
Linux是一种自由和开放源代码的类UNIX操作系统。该操作系统的内核由林纳斯·托瓦兹在1991年10月5日首次发布。在加上用户空间的应用程序之后,成为Linux操作系统。Linux也是自由软件和开放...
- hp laserjet p1108打印机驱动
-
惠普LaserJetProP1108打印机安装打印机驱动的方法,可以通过以下步骤操作来实现:1、运行驱动安装包,在“HPLaserJetProP1100打印机系列”下,点击“USB安装...
- 台式机最好的配置(台式机最强配置)
-
家用台式电脑cpu一般选择英特尔8-10代的i3就能满足正常的家用,内存方面选择16g,绝对够用,再选择一块512g的固态硬盘,保证电脑的速度2022年台式电脑建议你可以配16gb或32gb的内存。硬...
- 笔记本电脑home键在哪(笔记本的home键怎么用)
-
home键位置一般有三个:一、键就在键盘最右边一列的上方,也是右上角处。二、在数字键盘的“7”键上,如果想使用"home"键功能,需要先关闭数字键功能。一般笔记本开、关数字键功能是按F...
- win7汉化包下载(win7系统汉化)
-
要下载犀牛7grasshopper汉化包,首先你需要从官方网站或可靠的第三方网站上找到可信赖的下载链接。然后,点击链接进行下载,并确保你的电脑设备有足够的存储空间来安装这个汉化包。安装完成后,打开犀牛...
- ghost系统备份与恢复的详细步骤
-
还原系统步骤。1、电脑开机进入ghost,这里注意如果是通过U盘启动盘进入,注意先进入bios把第一启动项设置为当前的U盘;如果是通过自身电脑硬盘启动,建议先把ghost系统安装好。2、点击确定,然后...
- photoshop官方下载电脑版(ps软件官方下载中文版电脑版)
-
鼠标右键点击压缩包,点击解压到文件夹按钮。打开文件夹,点击安装文件。弹出安装对话框,点击默认位置。更改安装路径,点击确认按钮。等待安装完成,双击打开ps快捷方式即可。目前在电脑上免费下载PS是不太可能...
- 2025最火电脑壁纸(2025最火电脑壁纸全屏)
-
要更改MacBookPro2022的壁纸,可以按照以下步骤操作:首先,点击桌面上的空白区域,然后选择“更改桌面背景”选项。接着,从预设的壁纸中选择一个或者点击“+”号添加自己的图片。如果需要更改壁...
- 安装系统安装包(系统安装包里的安装文件在哪)
-
oppocoloros13具体的下载方法如下,第一步,手机打开OPPO官方网站服务中心,登录手机账号。第二步,找到coloroS13升级包,点击安全下载,将coloroS13系统升级软件包...
- u盘2t为什么才30元(为什么u盘128g那么便宜)
-
因为它是假的!之前我买了一个,说什么双十一搞活动,256G的U盘,花了30多元都是假的!楼主描述的这个情况百分之九十九是假的U盘!右击U盘,然后点“属性”,看到的可能是2T,但实际存储量却远没有2T,...
- 笔记本cpu90度正常吗(笔记本cpu 90多度)
-
如果运行大型游戏的话,还算正常。如果只是开个小游戏那就有点问题了。只要低于Intel原厂规范温度(105或100度),都不会影响产品寿命,CPU本身皆有保护机制,当核心超过设定的调节温度时,将会降...
- win10家庭版系统官网(windows10家庭版官网)
-
微软官网下载的WIN10系统需要制作成U盘安装盘才能安装。也可以直接在微软官网制作U盘安装盘。微软官网只提供原版(也就是纯净版的)系统的下载,需要用户自行永久激活后才是正版的。如果不是永...
- win7系统语言包(w7语言包在哪里)
-
1.单击桌面左下角的开始菜单,打开“控制面板”。2.在“控制面板”中找到“区域和语言”选项,点击该选项。3.弹出“区域和语言”属性对话框,切换到“管理选项”。4.点击“更改系统区域设置”...
- 照片恢复软件免费(照片恢复软件免费版)
-
苹果照片恢复软件是一款专业的免费的数码照片恢复软件,苹果照片恢复软件将成为你恢复丢失照片的最佳助手,它内核采用多种JPEG开发规范进行精确查找,支持多种品牌相机的拍摄格式。有极快的速度,可快速恢复被误...
- autocad2012产品密钥(cad2012的产品密钥是什么)
-
CAD2012产品密钥和序列号序列号:400-45454545钥匙:651D1序列号:356-72378422钥匙:001D1序列号:400-45454545钥匙:001D1序列号:666-6969...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
