问题php
在Prima/Plesk/Virtuozzo上,apache都使用了系统自带的httpd-2.0.5x的rpm包linux
在redhat linux上,默认使用的是prefork模式,而不是worker模式web
如何在两者间切换?apache
解决方案服务器
Apache HTTP服务器被设计为一个强大的、灵活的可以在多种平台以及不一样环境下工做的服务器。网络
不一样的平台和不一样的环境常常产生不一样的需求,或是为了达到一样的最佳效果而采用不一样的方法。多线程
Apache凭借它的模块化设计很好的适应了大量不一样的环境。并发
这一设计使得网站管理员可以在编译时和运行时凭借载入不一样的模块来决定服务器的不一样附加功能。ide
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认证相关的问题)。