查看Apache并发请求数及其TCP链接状态解释 [转载--张宴]

这两天搭建了一组Apache服务器,每台服务器4G内存,采用的是prefork模式,一开始设置的链接数太少了,须要较长的时间去响应用户的请求,后来修改了一下Apache 2.0.59的配置文件httpd.conf:
服务器

引用并发

# prefork MPM
# StartServers: number of server processes to start
# MinSpareServers: minimum number of server processes which are kept spare
# MaxSpareServers: maximum number of server processes which are kept spare
# MaxClients: maximum number of server processes allowed to start
# MaxRequestsPerChild: maximum number of requests a server process serves

StartServers         10
MinSpareServers      10
MaxSpareServers      15
ServerLimit          2000
MaxClients           2000
MaxRequestsPerChild  10000
tcp




  查看httpd进程数(即prefork模式下Apache可以处理的并发请求数):
  Linux命令:
ide

引用spa

ps -ef | grep httpd | wc -lorm


  返回结果示例:
  1388
  表示Apache可以处理1388个并发请求,这个值Apache可根据负载状况自动调整,我这组服务器中每台的峰值曾达到过2002。
server



  查看Apache的并发请求数及其TCP链接状态:
  Linux命令:
blog

引用进程

netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'内存


  (这条语句是从新浪互动社区事业部技术总监王老大那儿得到的,很是不错)
  返回结果示例:
  LAST_ACK 5
  SYN_RECV 30
  ESTABLISHED 1597
  FIN_WAIT1 51
  FIN_WAIT2 504
  TIME_WAIT 1057
  其中的SYN_RECV表示正在等待处理的请求数;ESTABLISHED表示正常数据传输状态;TIME_WAIT表示处理完毕,等待超时结束的请求数。



  关于TCP状态的变迁,能够从下图形象地看出:
  wKiom1Q_csayz8T7AACGHr-AhvE849.gif
  状态:描述
  CLOSED:无链接是活动的或正在进行
  LISTEN:服务器在等待进入呼叫
  SYN_RECV:一个链接请求已经到达,等待确认
  SYN_SENT:应用已经开始,打开一个链接
  ESTABLISHED:正常数据传输状态
  FIN_WAIT1:应用说它已经完成
  FIN_WAIT2:另外一边已赞成释放
  ITMED_WAIT:等待全部分组死掉
  CLOSING:两边同时尝试关闭
  TIME_WAIT:另外一边已初始化一个释放
  LAST_ACK:等待全部分组死掉