关于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认证相关的问题)。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


网站标题:关于Apache的prefork和worker模式切换-创新互联
转载来于:http://myzitong.com/article/joopo.html