`
xdy2008
  • 浏览: 54101 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

apache httpd的最大连接数合理设置

阅读更多
新配置的服务器,带宽 是2M ,apache httpd上传的速度比下载速度大很多,一直不解原因。

而且,apache httpd 链接数一旦超过200以上,网页打开速度就超级慢。特别郁闷。难道自己买了服务器还不如虚拟空间的!折磨中,于是上网搜索了一下,结果如下:虽然经过修改,好像有一些变化了,但是好像apache httpd链接数一超过200网页打开速度依然很慢,难道真的是带宽太低吗?设置了apache 缓存 也按下面的设置了 apache httpd 最大链接数。郁闷中!

新买了服务器,有一个网站在线人数增多,访问时很慢。初步认为是服务器带宽太低,但经反复测试,一旦连接上,不断点击同一个页面上不同的链接,都能迅速打开,这种现象就是说明apache最大连接数已经满了,新的访客只能排队等待有空闲的链接,而如果一旦连接上,在keeyalive 的存活时间内(KeepAliveTimeout,默认5秒)都不用重新打开连接,因此解决的方法就是加大apache的最大连接数。

1.在哪里设置?

apache 2.24,使用默认配置,默认最大连接数是150

首先在httpd.conf中加载httpd-mpm.conf配置(去掉前面的注释):
# Server-pool management (MPM specific)
Include conf/extra/httpd-mpm.conf

可见的MPM配置在Apache2.2/conf/extra/httpd-mpm.conf,但里面根据httpd的工作模式分了很多块,哪一部才是当前httpd的工作模式呢?可通过执行 apachectl -l 来查看:
Compiled in modules:
core.c
prefork.c
http_core.c
mod_so.c

所以修改连接数就在Apache2.2/conf/extra/httpd-mpm.conf这个文件了,打开它就找到prefork模式的默认配置是:
<IfModule mpm_prefork_module>
StartServers                      5
MinSpareServers                   5
MaxSpareServers                  10
MaxClients                      150
MaxRequestsPerChild               0
</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 httpd|wc -l来确认),那么后面的请求就要排队,直到某个已处理请求完毕。这就是系统资源还剩下很多而HTTP访问却很慢的主要原因。虽然理论上这个值越大,可以处理的请求就越多,但Apache默认的限制不能大于256。ServerLimit指令无须重编译Apache就可以加大MaxClients。

注意,虽然通过设置ServerLimit,我们可以把MaxClients加得很大,但是往往会适得其反,系统耗光所有内存。以我手头的一台服务器为例:内存2G,每个apache进程消耗大约0.5%(可通过ps aux来确认)的内存,也就是10M,这样,理论上这台服务器最多跑200个apache进程就会耗光系统所有内存,所以,设置MaxClients要慎重。

2.要加到多少?

连接数理论上当然是支持越大越好,但要在服务器的能力范围内,这跟服务器的CPU、内存、带宽等都有关系。

查看当前的连接数可以用:
ps aux | grep httpd | wc -l

或:
pgrep httpd|wc -l

计算httpd占用内存的平均数:
ps aux|grep -v grep|awk ‘/httpd/{sum+=$6;n++};END{print sum/n}’

由于基本都是静态页面,CPU消耗很低,每进程占用内存也不算多,大约200K。

服务器内存有2G,除去常规启动的服务大约需要500M(保守估计),还剩1.5G可用,那么理论上可以支持1.5*1024*1024*1024/200000 = 8053.06368

约8K个进程,支持2W人同时访问应该是没有问题的(能保证其中8K的人访问很快,其他的可能需要等待1、2秒才能连上,而一旦连上就会很流畅)

控制最大连接数的MaxClients ,因此可以尝试配置为:
<IfModule mpm_prefork_module>
StartServers                      5
MinSpareServers                   5
MaxSpareServers                  10
ServerLimit                    5500
MaxClients                     5000
MaxRequestsPerChild               100
</IfModule>

注意,MaxClients默认最大为250,若要超过这个值就要显式设置ServerLimit,且ServerLimit要放在MaxClients之前,值要不小于MaxClients,不然重启httpd时会有提示。

重启httpd后,通过反复执行pgrep httpd|wc -l 来观察连接数,可以看到连接数在达到MaxClients的设值后不再增加,但此时访问网站也很流畅,那就不用贪心再设置更高的值了,不然以后如果网站访问突增不小心就会耗光服务器内存,可根据以后访问压力趋势及内存的占用变化再逐渐调整,直到找到一个最优的设置值。

(MaxRequestsPerChild不能设置为0,可能会因内存泄露导致服务器崩溃)

更佳最大值计算的公式:

apache_max_process_with_good_perfermance < (total_hardware_memory / apache_memory_per_process ) * 2
apache_max_process = apache_max_process_with_good_perfermance * 1.5

分享到:
评论

相关推荐

    设置Apache最大连接数

    特别是在高并发场景下,合理设置Apache的最大连接数(即`MaxClients`参数),能够显著提升服务器响应速度与承载能力。 #### 知识点二:`MaxClients`参数详解 - **定义**:`MaxClients`参数用于定义Apache服务器能...

    查看apache连接的连接并发数

    MaxClients参数指定了Apache服务器的最大客户端连接数,即Apache服务器能够处理的最大并发请求数量。MaxRequestsPerChild参数指定了每个httpd进程能够处理的最大请求数量。 在实际应用中,管理员可以根据服务器的...

    Apache中配置最大并发用户数 tcp连接设置.docx

    Apache 中配置最大并发用户数 TCP 连接设置 Apache 是一个功能强大且灵活的 Web 服务器,可以根据不同的需求进行配置和优化。本文主要介绍如何配置 Apache 的最大并发用户数和 TCP 连接设置,以提高 Web 服务器的...

    Apache增加最大连接数的方法

    增加apache最大连接数的方法: 在httpd.conf中设置: MaxClients n n是整数,表示最大连接数,取值范围在1和256之间,如果要让apache支持更多的连接数,那么需要修改源码中的httpd.h文件,把定义的HARD_SERVER_...

    Apache的httpd.conf文件配置

    - `MaxClients` 控制同时处理的最大客户端连接数。 - `MaxRequestsPerChild` 指定每个子进程最多处理的请求数,达到限制后该子进程会被销毁并创建新的子进程。 #### 三、“主”服务器配置 ('Main' server ...

    Apache2httpd.conf配置文件中文版详解宣贯.pdf

    * MaxKeepAliveRequests:在稳固连接期间允许的最大请求数,设为 0 表示无限制接入。 * KeepAliveTimeout:在同一个连接上从同一台客户上接收请求的秒数。 第三部分:虚拟主机的设置参数 -------------------------...

    Apache2 httpd.conf 中文版

    - **MaxClients**: 最大并发客户端连接数。 - **MaxRequestsPerChild**: 每个工作子进程可以处理的最大请求数量。 示例配置如下: ```conf StartServers 5 MinSpareServers 5 MaxSpareServers 10 MaxClients ...

    Linux下Apache并发连接数和带宽控制

    在Linux环境下,Apache的并发连接数和带宽可以通过两个模块来实现:mod_limitipconn和mod_bandwidth。这两个模块是由Apache社区的开发者创建的,用于增强服务器的管理能力。 1. **mod_limitipconn**: 这个模块...

    windows下的apache限制IP连接数

    标题中的“Windows下的Apache限制IP连接数”是指在Windows操作系统上使用Apache web服务器时,如何配置服务器以限制每个IP地址的并发连接数。这是一项重要的安全策略,可以防止恶意用户或DDoS攻击通过大量并发连接...

    Apache的httpd.conf文件常用指令解释

    设定单个持久连接的最大请求数。 14. **Timeout**: 设置服务器等待客户端响应的超时时间。 15. **MimeTypes**: 通过AddType指令添加新的文件类型与MIME类型关联,例如:“AddType application/pdf .pdf”。 ...

    apache httpd rpm包,支持rpm一键安装维护

    - 通过调整httpd.conf中的配置,例如最大连接数、超时设置等,可以优化服务器性能。 - 使用模块如`mod_deflate`进行内容压缩,减少网络传输量,提高响应速度。 总的来说,Apache HTTPD的RPM包为CentOS用户提供了...

    apache的httpd.conf文件配置详解

    每个进程处理一个请求,配置参数如`StartServers`、`MinSpareServers`、`MaxSpareServers`、`MaxClients`和`MaxRequestsPerChild`分别控制启动的初始进程数、最小和最大空闲进程数、最大并发连接数以及每个进程处理...

    apache2.2 windows安装版 httpd-win32-src.zip

    9. **性能优化**:根据服务器硬件和预期负载,可以调整配置以优化性能,例如调整最大连接数、开启线程池等。 10. **安全注意事项**:保持Apache版本更新以修复已知安全漏洞。限制不必要的模块加载,防止潜在的安全...

    APACHE 流量控制及连接数限制.

    ### Apache流量控制及连接数限制 #### 概述 在Apache服务器配置中,流量控制与连接数限制是非常重要的环节,能够有效地防止服务器资源被滥用,确保服务稳定运行。本文将详细介绍如何实现Apache服务器上的流量控制...

    Apache连接数

    在集群环境中,当 Apache 遇到最大连接数不足的问题时,需要调整相关配置以提高其并发处理能力。本文将深入探讨如何在 Windows 环境下解决 Apache 连接数不足的问题。 首先,我们可以看到两种修改 Apache 配置以...

    apache2 httpd文件配置参数.txt

    - **MaxClients**:最大客户端连接数,默认值为 150。 - **MaxRequestsPerChild**:每个子进程处理的最大请求数量,设置为 0 表示不限制。 #### worker MPM - **StartServers**:启动时的初始工作子进程数量,...

    apache for httpd-2.2.6

    由于其强大的功能、灵活性和广泛的社区支持,Apache被全球数百万网站所采用。 **版本2.2.6的特点** - **安全性增强**:2.2.6版修复了多个安全漏洞,提高了服务器的安全性,防止恶意攻击。 - **模块化设计**:Apache...

    Apache配置文件httpd详解

    - **MaxClients**: 允许的最大客户端连接数。 - **MaxRequestsPerChild**: 单个服务器进程可以处理的最大请求数量。设置为0表示无限。 ```apache StartServers 5 MinSpareServers 5 MaxSpareServers 10 ...

Global site tag (gtag.js) - Google Analytics