3

fastcgi 配置中有 4 个字段,max-procs、max-load-per-proc、PHP_FCGI_CHILDREN、PHP_FCGI_MAX_REQUESTS:

fastcgi.server = ( ".php" =>
  (( "socket" => "/tmp/php-fastcgi.socket",
     "bin-path" => "/usr/local/bin/php",
     "max-procs" => "2",
     "bin-environment" => ( 
                           "PHP_FCGI_CHILDREN" => "3",
                           "PHP_FCGI_MAX_REQUESTS" => "10000" )
   ))
)
  • 由于 fastcgi.server 中只有 1 个条目,因此会有 1 个 Fastcgi 后端。
  • 由于 PHP_FCGI_CHILDREN =3 和 max-procs=2,“/usr/local/bin/php”进程的数量将是 2*(3+1)=7。
  • 由于 max-procs=2,在服务器状态下,会有 fastcgi.backend.0.0 和 fastcgi.backend.0.1 的状态

因此,将有 1 个带有 2 个进程的 fastcgi 后端。这些进程接受负载。

我不明白以下内容:

  1. PHP_FCGI_CHILDREN 的意义是什么?
  2. 请求是由 PHP_FCGI_CHILDREN 还是由 proc 处理的?
  3. 哪个参数决定 1 proc 的最大负载?它的默认值是多少?
  4. proc 的最大负载是否与 PHP_FCGI_MAX_REQUESTS 有任何关系?
  5. 如果 PHP_FCGI_CHILDREN=0 会发生什么?有人提到 max-proc = 观察者的数量和 max-proc*PHP_FCGI_CHILDREN = 工人的数量。这意味着什么?
  6. 什么时候说 proc 超载?
4

1 回答 1

2

希望这可以说明情况

这个答案的其余部分的一点背景:

“主”进程是产生的进程。这能够与它的孩子共享它的所有资源[比如内存]。但是不处理 php 请求,将其视为实际请求处理程序的容器

“子”进程是实际处理 php 请求的过程。反过来,这也是您在“主”进程上施加多少负载的一个非常重要的因素。

这里的一般策略应该是最小化“主”进程的数量并最大化“子”进程的数量,同时保持稳定性,因为子进程将与其兄弟姐妹共享 opcache、内存空间和系统资源。

  1. PHP_FCGI_CHILDREN=“主”进程可以产生的子进程的数量。
  2. 请求由PHP_FCGI_CHILDREN
  3. PHP_FCGI_CHILDREN它默认为1,如果设置为另一个值,则始终将 1 添加到您指定的数字 [所以如果您将其指定为 1 它会添加 1,因此它将变为 2 ]
  4. 是的,它确实
  5. 如果您设置PHP_FCGI_CHILDREN=0每个“主”进程将只产生 1 个子进程
  6. 当一个 proc 无法处理更多请求时,它会过载[由于缺乏资源] 这是非常依赖于系统/环境的,很抱歉在这里如此模糊
于 2018-11-12T14:38:10.253 回答