千家信息网

关于Apache的prefork和worker模式切换

发表于:2024-11-12 作者:千家信息网编辑
千家信息网最后更新 2024年11月12日,问题在Prima/Plesk/Virtuozzo上,apache都使用了系统自带的httpd-2.0.5x的rpm包在redhat linux上,默认使用的是prefork模式,而不是worker模式
千家信息网最后更新 2024年11月12日关于Apache的prefork和worker模式切换


问题

  在Prima/Plesk/Virtuozzo上,apache都使用了系统自带的httpd-2.0.5x的rpm包

  在redhat linux上,默认使用的是prefork模式,而不是worker模式

  如何在二者间切换?

解决方案

  Apache HTTP服务器被设计为一个强大的、灵活的能够在多种平台以及不同环境下工作的服务器。

  不同的平台和不同的环境经常产生不同的需求,或是为了达到同样的最佳效果而采用不同的方法。

  Apache凭借它的模块化设计很好的适应了大量不同的环境。

  这一设计使得网站管理员能够在编译时和运行时凭借载入不同的模块来决定服务器的不同附加功能。

  Apache2.0将这种模块化的设计延伸到了web服务器的基础功能上。

  这个版本带有多路处理模块(MPM)的选择以处理网络端口绑定、

  接受请求并指派子进程来处理这些请求。

  比如,需要更好伸缩性的可以选择象worker或event这样线程化的MPM,

  而需要更好的稳定性和兼容性以适应一些旧的软件可以用prefork 。

  在Redhat Linux的主要版本as4上,apache版本为httpd-2.0.5x,

  默认为prefork模式,主要是考虑到稳定性的原因。

  要切换到worker模式,则需要登录到linux上,进行如下操作:

  进入/usr/sbin目录

  cd /usr/sbin

  将当前的prefork模式启动文件改名

  mv httpd httpd.prefork

  将worker模式的启动文件改名

  mv httpd.worker httpd

  修改配置文件vi /etc/httpd/conf/httpd.conf

  找到里边的如下一段,可适当修改负载等参数:

  

  StartServers 5
ThreadLimit 200
ServerLimit 50
MaxClients 2000
MinSpareThreads 25
MaxSpareThreads 200
ThreadsPerChild 100
MaxRequestsPerChild 50

  

  重新启动服务

  /etc/init.d/httpd restart

  即可换成worker方式启动apache2

总结:

1. prefork 中没有线程的概念,是多进程模型,一个进程处理一个连接;稳定;响应快。其缺点是在连接数比较大时就非常消耗内存。

2. worker 是多进程多线程模型,一个进程有多个线程,每个线程处理一个连接。与prefork相比,worker模式更节省系统的内存资源。不过,需要注意worker模式下的Apache与php等程序模块的兼容性。

3. event 是worker模式的变种,它把服务进程从连接中分离出来,在开启KeepAlive场合下相对worker模式能够承受的了更高的并发负载。event模式不能很好的支持https的访问(HTTP认证相关的问题)。


0