`
samuschen
  • 浏览: 405538 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

apache并发数调整

阅读更多

转载   apache并发数调整 收藏

 

手头有一个网站在线人数增多,访问时很慢。初步认为是服务器资源不足了,但经反 复测试,一旦连接上,不断点击同一个页面上不同的链接,都能迅速打开,这种现象就是说明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并发数与带宽限制知识点详解 #### 一、并发数限制 **并发数限制**是Apache服务器中一项重要的功能,它可以帮助管理员控制每个虚拟主机的最大并发连接数,从而避免服务器因过载而崩溃。 ##### 1.1 下载...

    查看apache连接的连接并发数

    "查看Apache连接的连接并发数" Apache连接是Apache服务器处理并发请求的关键指标之一。Apache服务器的连接并发数是指Apache服务器能够处理的最大并发请求数量。在prefork模式下,Apache服务器的连接并发数取决于...

    Apache2.2安全配置和性能优化

    **Apache并发数调整:** - **MPM配置加载**:MPM(Multi-Processing Module)是指多处理模块,它定义了Apache如何处理请求。在Apache2.2中,可以通过编辑`httpd.conf`文件并取消`#Server-poolmanagement (MPM ...

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

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

    apache并发连接查看

    ### Apache并发连接查看知识点详解 #### 一、引言 在服务器运维与管理过程中,了解Apache服务器的并发连接情况对于评估服务器性能、优化资源分配至关重要。通过查看Apache并发链接,我们可以直观地了解到Apache的...

    查看Apache并发请求数及其TCP连接状态.pdf

    了解Apache的并发请求数和TCP连接状态对于监控服务器性能、优化资源分配以及解决可能的性能瓶颈至关重要。以下是一些关键知识点: 1. **并发请求数**: - Apache的并发请求数是指同一时间服务器能够处理的客户端...

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

    这两个模块分别用于控制并发连接数和带宽使用,以确保服务器的稳定运行。 1. **mod_limitipconn**: mod_limitipconn模块允许管理员限制每个IP地址同时连接到服务器特定目录的并发连接数量。这对于防止恶意用户或...

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

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

    Apache限制IP并发数和流量控制的方法

    首先,我们来看如何限制IP并发数。Apache自身并不直接支持此功能,但可以通过第三方模块mod_limitipconn来实现。以下是安装和配置mod_limitipconn的步骤: 1. 下载模块源代码:`wget ...

    查看apache连接的连接并发数[参照].pdf

    本文将深入探讨如何查看Apache服务器在prefork模式下的连接并发数,以及通过Linux命令监控Apache的TCP连接状态。 首先,Apache的prefork模型是一种多进程模型,每个进程(也称为服务器进程)可以处理一个单独的...

    设置Apache最大连接数

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

    Apache连接数

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

    windows下的apache限制IP连接数

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

    ApacheBench测试详解

    - 基本命令格式:`ab -n &lt;请求次数&gt; -c &lt;并发数&gt; &lt;URL&gt;` - `-n` 参数定义了要发送的请求数量。 - `-c` 参数定义了同时进行的并发请求数。 - `&lt;URL&gt;` 是要测试的Web服务器地址。 **二、主要选项及参数** 1. **...

    mysql+apache+php

    为了提高服务器的安全性和性能,还需要进一步的优化和配置,例如调整MySQL的配置参数,限制Apache的并发连接数,设置防火墙规则,以及定期备份数据库等。此外,还可以考虑安装其他软件,如PHPMyAdmin进行数据库管理...

    apache优化和模块安装

    首先,Apache 的最大连接数优化涉及到对服务器资源的合理分配,以处理更多的并发请求。在描述中提到,通过修改 Apache 源代码中的常量 DEFAULT_SERVER_LIMIT 和 MAX_SERVER_LIMIT 来设置最大服务器限制,以及 ...

    apache_2.2.6_win32

    性能优化则包括限制并发连接数、使用缓存模块(如`mod_cache`)、调整内存分配策略等。 8. **与其他软件集成** Apache常与PHP、MySQL等一起用于构建LAMP(Linux, Apache, MySQL, PHP)或WAMP(Windows, Apache, ...

    网页并发测试小工具ApacheBench

    1. **基本用法**:`ab -n &lt;请求总数&gt; -c &lt;并发数&gt; &lt;URL&gt;`,其中-n指定总的请求数,-c指定并发连接数,URL是待测试的Web地址。 2. **其他参数**: - `-p`:指定包含POST数据的文件。 - `-T`:指定POST数据的MIME...

    利用autobench测试web服务器极限并发数.pdf

    然而,当并发数达到1500时,Apache的响应时间显著增加,而Nginx仍然能保持较低的响应时间,表明Nginx在处理高并发连接时的性能更优。 - 动态文件测试(如/User/Register.php)也反映了类似的情况,通过对比实际并发...

    怎样确定一个实际系统的并发用户数

    并发用户数确定方法 在项目的性能测试过程中,确定一个实际系统的并发用户数是非常重要的步骤。并发用户数是指在同一时间段内访问系统的用户数量,影响着系统的性能和稳定性。本文将详细介绍如何确定一个实际系统的...

Global site tag (gtag.js) - Google Analytics