- 浏览: 2542487 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (676)
- linux运维 (157)
- php (65)
- mysql (78)
- nginx (27)
- apche (18)
- framework (6)
- windows (9)
- IDE工具 (23)
- struts2 (7)
- java (13)
- 移动互联网 (14)
- memcache redis (23)
- shell基础/命令/语法 (37)
- shell (50)
- puppet (4)
- C (11)
- python (9)
- 产品经理 (27)
- Sphinx (4)
- svn (12)
- 设计构建 (12)
- 项目管理 (44)
- SEO (1)
- 网站架构 (26)
- 审时度势 (42)
- 网络 (14)
- 激发事业[书&视频] (81)
- 其它 (12)
- 摄影 (8)
- android (21)
最新评论
-
zhongmin2012:
原文的书在哪里
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
renzhengzhi:
你好,请问个问题,从master同步数据到slave的时候,s ...
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
ibc789:
你好,看了你的文章,我想请教个问题, 我在用 redis的时候 ...
redis 的两种持久化方式及原理 -
iijjll:
写得非常好
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
iijjll:
写得非常好
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器
如何知道当前apache的应用模式
httpd -l 或者apache2 -l
如果有
prefork.c
那就是
prefork
方式,如果是
worker.c
那就是
work
模式。
root@ubuntu-desktop:/etc/apache2/mods-enabled
# apache2 -l
Compiled in modules:
core.c
mod_log_config.c
mod_logio.c
prefork.c
http_core.c
mod_so.c
----------------------------------------------
<IfModule prefork.c>
StartServers 8
MinSpareServers 5
MaxSpareServers 20
ServerLimit 256
MaxClients 256
MaxRequestsPerChild 4000
</IfModule>
[root@localhost ~]# ps auxf | grep apache |wc -l
20
[root@localhost ~]# ps auxf | grep apache
apache 3856 0.2 3.8 58052 39336 ? S 00:12 2:25 \_ /usr/sbin/httpd
apache 20952 0.2 3.8 57992 39280 ? S 04:04 1:52 \_ /usr/sbin/httpd
apache 22231 0.2 3.8 57988 39200 ? S 04:12 1:57 \_ /usr/sbin/httpd
apache 22237 0.2 3.8 57960 39300 ? S 04:12 1:52 \_ /usr/sbin/httpd
apache 29719 0.2 3.8 57980 39020 ? S 05:08 1:47 \_ /usr/sbin/httpd
apache 29757 0.2 3.8 58292 39428 ? S 05:09 1:42 \_ /usr/sbin/httpd
apache 29816 0.2 2.3 43024 24228 ? S 05:09 1:41 \_ /usr/sbin/httpd
apache 25362 0.2 1.7 37184 18408 ? S 11:45 0:58 \_ /usr/sbin/httpd
apache 30748 0.2 1.5 34404 15600 ? S 12:22 0:42 \_ /usr/sbin/httpd
apache 5892 0.2 1.3 32980 13840 ? S 12:57 0:35 \_ /usr/sbin/httpd
apache 6198 0.2 1.4 33408 14408 ? S 12:57 0:35 \_ /usr/sbin/httpd
apache 6219 0.2 1.4 34160 14948 ? S 12:57 0:38 \_ /usr/sbin/httpd
apache 7211 0.2 1.3 32772 13804 ? S 13:00 0:33 \_ /usr/sbin/httpd
apache 7727 0.2 1.3 33072 14036 ? S 13:02 0:35 \_ /usr/sbin/httpd
apache 19977 0.2 1.3 33240 14104 ? S 14:26 0:23 \_ /usr/sbin/httpd
apache 13485 0.2 1.3 33232 13788 ? S 16:16 0:10 \_ /usr/sbin/httpd
apache 13712 0.2 1.3 33044 13584 ? S 16:18 0:09 \_ /usr/sbin/httpd
apache 14653 0.2 1.3 32660 13620 ? S 16:22 0:08 \_ /usr/sbin/httpd
apache 21534 0.1 1.3 32656 13508 ? S 17:06 0:02 \_ /usr/sbin/httpd
apache 22834 0.1 1.2 32712 13260 ? S 17:19 0:00 \_ /usr/sbin/httpd
如果你的系统内存不是很充足或者运行有其他的服务,把MaxSpareServers设置小一些可以为
其他服务空出一些内存
------------ 重启apache
[root@localhost ~]# ps auxf | grep apache | wc -l
9
[root@localhost ~]# ps auxf | grep apache
apache 24900 0.6 1.0 32268 11260 ? S 17:34 0:00 \_ /usr/sbin/httpd
apache 24901 0.0 0.7 30444 7580 ? S 17:34 0:00 \_ /usr/sbin/httpd
apache 24902 0.0 0.7 30308 7584 ? S 17:34 0:00 \_ /usr/sbin/httpd
apache 24903 0.5 1.0 31876 11276 ? S 17:34 0:00 \_ /usr/sbin/httpd
apache 24904 0.0 0.7 30444 7608 ? S 17:34 0:00 \_ /usr/sbin/httpd
apache 24905 1.1 1.1 32452 12068 ? S 17:34 0:00 \_ /usr/sbin/httpd
apache 24906 0.6 1.1 32216 11808 ? S 17:34 0:00 \_ /usr/sbin/httpd
apache 24907 0.6 1.1 32324 11888 ? S 17:34 0:00 \_ /usr/sbin/httpd
apache 24909 0.0 0.7 30444 7604 ? S 17:34 0:00 \_ /usr/sbin/httpd
---------------------------------------------关于Apache的prefork和worker工作模式
prefork模式
这个多路处理模块(MPM)实现了一个非线程型的、预派生的web服务器,它的工作方式类似于Apache 1.3。它适合于没有线程安全库,需要避免线程兼容性问题的系统。它是要求将每个请求相互独立的情况下最好的MPM,这样若一个请求出现问题就不会影响到其他请求。
这个MPM具有很强的自我调节能力,只需要很少的配置指令调整。最重要的是将MaxClients设置为一个足够大的数值以处理潜在的请求高峰,同时又不能太大,以致需要使用的内存超出物理内存的大小。
worker模式
此多路处理模块(MPM)使网络服务器支持混合的多线程多进程。由于使用线程来处理请求,所以可以处理海量请求,而系统资源的开销小于基于进程的MPM。但是,它也使用了多进程,每个进程又有多个线程,以获得基于进程的MPM的稳定性。
控制这个MPM的最重要的指令是,控制每个子进程允许建立的线程数的ThreadsPerChild指令,和控制允许建立的总线程数的MaxClients指令。
prefork和worker模式的切换
1.将当前的prefork模式启动文件改名
mv httpd httpd.prefork
2.将worker模式的启动文件改名
mv httpd.worker httpd
3.修改Apache配置文件
vi /usr/local/apache2/conf/extra/httpd-mpm.conf
找到里边的如下一段,可适当修改负载等参数:
<IfModule mpm_worker_module>
StartServers 2
MaxClients 150
MinSpareThreads 25
MaxSpareThreads 75
ThreadsPerChild 25
MaxRequestsPerChild 0
</IfModule>
4.重新启动服务
/usr/local/apache2/bin/apachectl restart
即可换成worker方式启动apache2
处于稳定性和安全性考虑,不建议更换apache2的运行方式,使用系统默认prefork即可。另外很多php模块不能工作在worker模式下,例如redhat linux自带的php也不能支持线程安全。所以最好不要切换工作模式。
prefork和worker模式的比较
prefork模式使用多个子进程,每个子进程只有一个线程。每个进程在某个确定的时间只能维持一个连接。在大多数平台上,Prefork MPM在效率上要比Worker MPM要高,但是内存使用大得多。prefork的无线程设计在某些情况下将比worker更有优势:它可以使用那些没有处理好线程安全的第三方模块,并 且对于那些线程调试困难的平台而言,它也更容易调试一些。
worker模式使用多个子进程,每个子进程有多个线程。每个线程在某个确定的时间只能维持一个连接。通常来说,在一个高流量的HTTP服务器 上,Worker MPM是个比较好的选择,因为Worker MPM的内存使用比Prefork MPM要低得多。但worker MPM也由不完善的地方,如果一个线程崩溃,整个进程就会连同其所有线程一起”死掉”.由于线程共享内存空间,所以一个程序在运行时必须被系统识别为”每 个线程都是安全的”。
总的来说,prefork方式速度要稍高于worker,然而它需要的cpu和memory资源也稍多于woker。
prefork模式配置详解
<IfModule mpm_prefork_module>
ServerLimit 256
StartServers 5
指定服务器启动时建立的子进程数量,prefork默认为5。
MinSpareServers 5
MaxSpareServers 10
MaxClients 256
限定同一时间客户端最大接入请求的数量(单个进程并发线程数),默认为256
。任何超过MaxClients限制的请求都将进入等候队列,一旦一个链接被释放,队列中的请求将得到服务。要增大这个值,你必须同时增大ServerLimit。
MaxRequestsPerChild 0
</IfModule>
ServerLimit
StartServers :默认的MaxClient最大是256个线程,如果想设置更大的值,就的加上ServerLimit这个参数。20000是ServerLimit这个参数的最大值。如果需要更大,则必须编译apache,此前都是不需要重新编译Apache。生效前提: ServerLimit 必须放在其他指令的前面
MinSpareServers:指定空闲子进程的最小数量,默认为5。 如果当前空闲子进程数少于MinSpareServers ,那么Apache将以最大每秒一个的速度产生新的子进程。此参数不要设的太大。
MaxSpareServers:设置空闲子进程的最大数量,默认为10。如果当前有超过MaxSpareServers数量的空闲子进程,那么父进程将杀死多余的子进程。此参数不要设的 太大。如果你将该指令的值设置为比MinSpareServers小,Apache将会自动将其修改成”MinSpareServers+1″。
MaxRequestsPerChild
每个子进程在其生存期内允许伺服的最大请求数量,默认为10000.到达MaxRequestsPerChild的限制后,子进程将会结束。如果 MaxRequestsPerChild为”0″,子进程将永远不会结束。将MaxRequestsPerChild设置成非零值有两个好处:
1.可以防止(偶然的)内存泄漏无限进行,从而耗尽内存。
2.给进程一个有限寿命,从而有助于当服务器负载减轻的时候减少活动进程的数量。
<IfModule mpm_prefork_module>
ServerLimit 2000
StartServers 10
MinSpareServers 10
MaxSpareServers 15
MaxClients 1500
MaxRequestsPerChild 10000
</IfModule>
worker模式配置详解
<IfModule mpm_worker_module>
StartServers 2
MaxClients 150
MinSpareThreads 25
MaxSpareThreads 75
ThreadsPerChild 25
MaxRequestsPerChild 0
</IfModule>
StartServers
服务器启动时建立的子进程数,默认值是”3″。
MaxClients
允许同时伺服的最大接入请求数量(最大线程数量)。任何超过MaxClients限制的请求都将进入等候队列。默认值是”400″ ,16(ServerLimit)乘以25(ThreadsPerChild)的结果。因此要增加MaxClients的时候,你必须同时增加 ServerLimit的值。
MinSpareThreads
最小空闲线程数,默认值是”75″。这个MPM将基于整个服务器监视空闲线程数。如果服务器中总的空闲线程数太少,子进程将产生新的空闲线程。
MaxSpareThreads
设置最大空闲线程数。默认值是”250″。这个MPM将基于整个服务器监视空闲线程数。如果服务器中总的空闲线程数太多,子进程将杀死多余的空闲线程。 MaxSpareThreads的取值范围是有限制的。Apache将按照如下限制自动修正你设置的值:worker要求其大于等于 MinSpareThreads加上ThreadsPerChild的和。
ThreadsPerChild
每个子进程建立的常驻的执行线程数。默认值是25。子进程在启动时建立这些线程后就不再建立新的线程了。
MaxRequestsPerChild
设置每个子进程在其生存期内允许伺服的最大请求数量。到达MaxRequestsPerChild的限制后,子进程将会结束。如果MaxRequestsPerChild为”0″,子进程将永远不会结束。将MaxRequestsPerChild设置成非零值有两个好处:
1.可以防止(偶然的)内存泄漏无限进行,从而耗尽内存。
2.给进程一个有限寿命,从而有助于当服务器负载减轻的时候减少活动进程的数量。
注意对于KeepAlive链接,只有第一个请求会被计数。事实上,它改变了每个子进程限制最大链接数量的行为。
-------------------------------------------apache的prefork和workder模式的性能
选择prefork还是worker可以在编译时使用–with-mpm=MPM参数指定,默认为prefork,prefork采用预派生子进程方式,用单独的子进程来处理 不同的请求,进程之间彼此独立。在make编译和make
install安装后,使用httpd -l来确定当前使用的MPM是prefork.c。查看httpd-mpm.conf配置文件,里面包含如下默认的配置段:
<IfModule prefork.c>
StartServers 5
MinSpareServers 5
MaxSpareServers 10
MaxClients 150
MaxRequestsPerChild 0
IXDBA.NET技术社区
</IfModule>
prefork
控制进程在最初建立“StartServers”个子进程后,为了满足MinSpareServers设置的需要创建一个进程,等待一秒钟,继续创建两个,再等待一秒钟,继续创建四个……如此按指数级增加创建的进程数
,最多达到每秒32个,直到满足MinSpareServers设置的值为止。这种模式可以不必在请求到来时再产生新的进程,从而减小了系统开销以增加性能。MaxSpareServers设置了最大的空闲进程数,如果空
闲进程数大于这个值,Apache会自动kill掉一些多余进程。这个值不要设得过大,但如果设的值比MinSpareServers小,Apache会自动把其调整为 MinSpareServers+1。
如果站点负载较大,可考虑同时加大MinSpareServers和MaxSpareServers。 MaxRequestsPerChild设置的是每个子进程可处理的请求数。每个子进程在处理了“MaxRequestsPerChild”个请求后将自动销
毁。0意味着无限,即子进程永不销毁。虽然缺省设为0可以使每个子进程处理更多的请求,但如果设成非零值也有两点重要的好处:1、可防止意外的内存泄漏。2、在服务器负载下降的时侯会自动减少
子进程数。因此,可根据服务器的负载来调整这个值。MaxClients是这些指令中最为重要的一个,设定的是 Apache可以同时处理的请求,是对Apache性能影响最大的参数。其缺省值150是远远不够的,
如果请求总数已达到这个值(可通过ps -ef|grep http|wc -l来确认),那么后面的请求就要排队,直到某个已处理请求完毕。这就是系统资源还剩下很多而HTTP访问却很慢的主要原因。虽然理论上这
个值越大,可以处理的请求就越多,但Apache默认的限制不能大于256。ServerLimit指令无须重编译Apache就可以加大MaxClients。
<IfModule prefork.c>
ServerLimit 10000
StartServers 5
MinSpareServers 5
MaxSpareServers 10
MaxClients 10000
MaxRequestsPerChild 0
</IfModule>
Worker
相对于prefork,worker全新的支持多线程和多进程混合模型的MPM。由于使用线程来处理,所以可以处理相对海量的请求,而系统资源的开销要小于基于进程的服务器。但是,worker也使用了多进程,
每个进程又生成多个线程,以获得基于进程服务器的稳定性。在configure –with-mpm=worker后,进行make编译、make install安装。在缺省生成的httpd-mpm.conf中有以下默认配置段:
<IfModule worker.c>
StartServers 2
MaxClients 150
MinSpareThreads 25
MaxSpareThreads 75
ThreadsPerChild 25
MaxRequestsPerChild 0
</IfModule>
Worker 由主控制进程生成“StartServers”个子进程,每个子进程中包含固定的ThreadsPerChild线程数,各个线程独立地处理请求。同样,为了不在请求到来时再生成线程,MinSpareThreads和
MaxSpareThreads设置了最少和最多的空闲线程数;而MaxClients 设置了同时连入的clients最大总数。如果现有子进程中的线程总数不能满足负载,控制进程将派生新的子进程。MinSpareThreads和
MaxSpareThreads的最大缺省值分别是75和250。这两个参数对Apache的性能影响并不大,可以按照实际情况相应调节。
ThreadsPerChild是worker MPM中与性能相关最密切的指令。ThreadsPerChild的最大缺省值是64,如果负载较大,64也是不够的。这时要显式使用 ThreadLimit指令,它的最大缺省值是20000。Worker模
式下所能同时处理的请求总数是由子进程总数乘以ThreadsPerChild 值决定的,应该大于等于MaxClients。如果负载很大,现有的子进程数不能满足时,控制进程会派生新的子进程。默认最大的子进程
总数是16,加大时也需要显式声明ServerLimit(最大值是20000)。需要注意的是,如果显式声明了ServerLimit,那么它乘以 ThreadsPerChild的值必须大于等于MaxClients,而且MaxClients必须是
ThreadsPerChild的整数倍,否则 Apache将会自动调节到一个相应值。
<IfModule worker.c>
ServerLimit 25
ThreadLimit 200
StartServers 3
MaxClients 2000
MinSpareThreads 50
MaxSpareThreads 200
ThreadsPerChild 100
MaxRequestsPerChild 0
</IfModule>
下面是利用Apache自带的测试工具ab对Server进行测试的情况(设定请求的index页面为6bytes),cpu%为cpu占用率,mem为内存使用量(M为单位),RequestsPerSecond为每秒处理的请求数。
1、Prefor方式
(ServerLimit,StartServer,MinSpareServers,MaxSpareServers,MaxClients,MaxRequestPerChild)
-n/-c(ab参数) Cpu% Mem Requestspersecond
(-,5,5,10,150,0)
100000/100 28.8 285 8434
100000/200 29.2 304 8032
100000/500 25.3 323 7348
100000/1000 24.4 330 5886
(10000,5,5,10,500,0)
100000/100 28.7 371 8345
100000/200 27.4 389 7929
100000/500 24.9 417 7229
100000/1000 23.4 437 6676
(10000,5,5,10,1000,0)
100000/100 28.8 408 8517
100000/200 27.0 422 8045
100000/500 24.2 455 7236
100000/1000 22.5 470 6570
(10000,5,5,10,1500,0)
100000/100 29.6 330 8407
100000/200 28.1 349 8014
100000/500 26.4 380 7290
100000/1000 24.0 400 6686
2、Worker方式
(ServerLimt,Threadlimt,Startservers,MaxClients,MinspareThread,MaxspareThread,ThreadperChild,MaxRequestPerChild)
-n/-c(ab参数) cpu% mem RequestsperSecond
(50,500,5,10000,50,200,200,0)
100000/100 18.6 188 6020
100000/200 20.1 195 5892
100000/500 19.8 209 5708
100000/1000 22.2 218 6081
(100,500,5,10000,50,200,100,0)
100000/100 24.5 240 6919
100000/200 23.6 247 6798
100000/500 24.6 254 6827
100000/1000 22.3 271 6114
(200,500,5,10000,50,200,50,0)
100000/100 27.3 301 7781
100000/200 27.4 307 7789
100000/500 26.0 320 7141
100000/1000 21.8 344 6110
相对来说,prefork方式速度要稍高于worker,然而它需要的cpu和memory资源也稍多于woker。
如何知道当前apache的应用模式
httpd -l 如果有prefork.c 那就是prefork方式,如果是worker.c那就是work模式。
忙的原因需要你对你网站进行行为分析。一般是分析日志。然后再根据实际情况做判断。
我曾经给个朋友做过优化。当时他的机器每到晚上LOAD基本都是几十。慢的很。我对日志进行了分析。发现有很多爬虫在访问动态的页面同时有很多IP在恶意的盗取图片数据等。导致大量的资源被消
耗掉。最后我采取了适当措施。现在LOAD基本都在1以下。所以分析访问行为是很重要的盲目的调整APACHE的连接参数意义真的是不大。希望我的话能够修正大家的一些不正确的想法。
发表评论
-
伪静态
2011-11-29 17:34 1437--------------------Apache ... -
关于Apache (httpd)服务器防DDOS模块mod_evasive的使用说明
2011-03-21 22:34 4086http://www.docin.com/p-83334545 ... -
[shell]Nginx/Apache日志分析脚本
2011-03-21 12:47 8487http://junlee.blog.51cto.com/22 ... -
Apache查看连接数和限制当前的连接数
2010-11-04 10:58 9408起因:线上的一台服务器,最近总是出现 访问 很慢的情况发生,点 ... -
http.conf优化,安全配置
2010-10-31 17:19 2826---------------------- apache日 ... -
【汇总】apache
2010-10-31 17:17 1235----------------apache SetEnv ... -
如何让apache支持.shtml 让apache支持include标签
2009-10-11 15:23 3679打开conf目录下的httpd.conf文件,搜索“AddTy ... -
[CentOS]apache+mod_ssl中证书生成方法
2009-10-07 10:58 3877--------------------------- ... -
启用Apache2 的mod_deflate(gzip)來压缩网页提高传输效能
2009-08-22 21:25 2672Apache2之后的版本,模块名不叫gzip,而叫mod_de ... -
apache的缓存mod_cache设置----待更新
2009-08-16 14:38 3841Apache模块 mod_cache 手册:http://la ... -
Apache中的mod_proxy模块应用
2009-08-16 13:39 9812Apache模块 mod_proxy手册:http://lam ... -
ubuntu apache2配置详解
2009-08-16 12:48 5971ubuntu apache2配置 1.apache2.con ... -
查看Apache的请求数和开启Apache Server Status
2009-08-16 11:58 6071在Linux下查看Apache的负 ... -
【维护】apache 配置和日志+shell
2009-08-13 09:49 1706apache安装目录 在phpinfo ... -
【汇总】Apache压测命令ab
2009-06-30 21:14 4030ab的全称是ApacheBench,是Apache附带的一 ... -
虚拟主机配置教程,包括apache mod_vhost_alias模块
2009-06-29 22:52 5334----------- /htdocs/test ... -
伪静态页面生成教程mod_rewrite
2009-06-23 09:48 3001从phpchina.com转载过来的,教程写的不错,容易理解 ...
相关推荐
Apache 提供了两种主要的 MPM:prefork 和 worker,它们各自有不同的工作原理和适用场景。 **prefork 模式** prefork 模式是一种非线程的、预派生的服务器模型,适用于那些没有线程安全库或需要避免线程兼容性问题...
与 Prefork 和 Worker MPM 不同,它采用了事件驱动的设计模式,允许服务器处理更多的并发请求,而不需要为每个连接分配一个线程。这种设计使得 Event MPM 成为了处理高并发请求的理想选择。 ##### 配置参数 - **...
apache常用的工作模式有prefork和worker模式。运行命令httpd -l 或者apache2 -l ,输出的结果中如果含有prefork.c,那就是prefork模式,如果结果中含有worker.c,那就是worker模式。 知道模式之后我们可以在apache的...
apache2-prefork 64位快速安装包
Linux 下apache2-prefork-2.2.22-i586.rpm 快速安装包
Apache 服务器是当前最流行的 Web 服务器之一,它提供了多种工作模式,包括 Prefork、Worker 和 Event 等。其中,Worker 工作模式是 Apache 2.x 版本中默认的工作模式。在 Worker 工作模式下,Apache 服务器使用多...
Apache的两种工作模式: prefork模式: 使用多个子进程,每个子进程只包含一个线程 特点:效率高,内存使用率高 worker模式 使用多个子进程,每个子进程包含多个线程 特点:内存使用率低,一个线程崩溃,整个...
本文将详细讨论Apache中的线程模式,包括`prefork`和`worker`两种主要的多进程模块(MPM)。 首先,`prefork`模式是Apache的默认MPM,它采用预派生子进程的方式来处理HTTP请求。每个请求由一个单独的子进程处理,...
在prefork模式下,Apache服务器的连接并发数取决于httpd进程数,即StartServers、MinSpareServers、MaxSpareServers、ServerLimit、MaxClients和MaxRequestsPerChild等配置参数的设置。 在prefork模式下,Apache...
- **配置参数调整**:`prefork`模式的配置参数主要包括`StartServers`、`MinSpareServers`、`MaxSpareServers`、`MaxClients`和`MaxRequestsPerChild`。其中,`MaxClients`定义了可以同时处理的最大客户端连接数,是...
本指南将详细讲解如何在Windows 64位操作系统上安装和配置Apache 2.4.6版本。 1. **下载Apache 64位版本** 在Windows上安装64位Apache,首先需要从官方或可靠的第三方站点下载。Apache Lounge...
为了提升性能,Apache2.2引入了多进程(MPM)模型,如Prefork和Worker模式。Prefork模式适用于内存充足的环境,每个进程只有一个线程;Worker模式则支持多线程,适合高并发场景。还可以通过调整MaxKeepAliveRequests...
传统上Apache有两种主要的运行模式,分别是prefork和worker。prefork模式在启动时就生成多个子进程,每个子进程处理一个请求,这种方式比较稳定,但会消耗较多的系统资源。worker模式则采用了多线程的方式,每个进程...
在 Linux 环境下,Apache 提供了多种多进程多线程模型,如 Prefork 和 Worker 模式,可以通过重新编译来选择工作模式。但在 Windows 系统中,Apache 默认使用的是 mpm_winnt 模式,无法通过编译选择其他工作模式。...
Apache支持两种主要的工作模式:预读取(Prefork)和worker模式。预读取模式下,Apache会预先创建多个子进程来处理请求,适合资源丰富的环境;worker模式则采用多线程,每个进程包含多个线程,适合内存有限但CPU...
以`prefork`模式为例,启动Apache服务: ```bash service httpd start ``` 查看进程情况: ```bash ps -ef|grep httpd |grep -v grep ``` 可以看到一个主进程和多个空闲进程。 #### 八、总结 本文详细介绍了在Linux...
5. **性能优化**:Apache 2.2引入了MPM(多进程模块),如Prefork MPM和Worker MPM,它们分别对应于进程模型和线程模型,以提高服务器处理并发请求的能力。用户可以根据服务器硬件资源和负载情况选择合适的MPM。 6....
本文主要介绍如何配置 Apache 的最大并发用户数和 TCP 连接设置,以提高 Web 服务器的性能和可扩展性。 1. 了解 MPM 模块 Apache 在编译时可以选择使用的 MPM(Multi-Processing Module)模块,使用./configure --...