`
ibadboy
  • 浏览: 84511 次
  • 性别: Icon_minigender_1
  • 来自: 江苏
社区版块
存档分类
最新评论

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

 
阅读更多
转载自:http://hi.baidu.com/rainchen/blog/item/095f0a551fa802c5b645ae46.html
手头有一个网站在线人数增多,访问时很慢。初步认为是服务器资源不足了,但经反复测试,一旦连接上,不断点击同一个页面上不同的链接,都能迅速打开,这种现象就是说明apache最大连接数已经满了,新的访客只能排队等待有空闲的链接,而如果一旦连接上,在keeyalive 的存活时间内(KeepAliveTimeout,默认5秒)都不用重新打开连接,因此解决的方法就是加大apache的最大连接数。

1.在哪里设置?

服务器的为FreeBSD 6.2 ,apache 2.24,使用默认配置(FreeBSD 默认不加载自定义MPM配置),默认最大连接数是250

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

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

看到prefork 字眼,因此可见当前httpd应该是工作在prefork模式,prefork模式的默认配置是:
<IfModule mpm_prefork_module>
                StartServers                      5
                MinSpareServers                   5
                MaxSpareServers                  10
                MaxClients                      150
                MaxRequestsPerChild               0
</IfModule>

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 2.0性能优化—MPM的选择与配置

如何避免apache的httpd进程占用比较多的内存

对apache中并发控制参数prefork理解和调优

附:

实时检测HTTPD连接数:
watch -n 1 -d "pgrep httpd|wc -l"
分享到:
评论

相关推荐

    设置Apache最大连接数

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

    查看apache连接的连接并发数

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

    Apache增加最大连接数的方法

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

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

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

    Apache的httpd.conf文件配置

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

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

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

    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”。 ...

    Apache2 httpd.conf 中文版

    - **MaxClients**:最大并发客户端连接数。 - **MaxRequestsPerChild**:每个子进程处理的最大请求数量。 **worker MPM** - **StartServers**:初始创建的子进程数量。 - **MaxClients**:最大并发客户端连接数。 -...

    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 配置以...

    apache for httpd-2.2.6

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

    apache2 httpd文件配置参数.txt

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

    Apache配置文件httpd详解

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

    apache-httpd-2.2.29-x64-r4.rar

    6. **性能优化**:可以通过调整最大连接数、超时设置、缓存策略等方式提升服务器性能。 7. **脚本支持**:Apache支持多种脚本语言,如PHP、Perl、Python等,使服务器能够运行动态网页。 8. **代理和负载均衡**:`...

Global site tag (gtag.js) - Google Analytics