Maison >développement back-end >Problème PHP >Quel est le chemin d'installation de php-fpm ?

Quel est le chemin d'installation de php-fpm ?

PHPz
PHPzoriginal
2020-09-25 16:00:256131parcourir

Le chemin d'installation de php-fpm : 1. Dans les plateformes Linux telles que centos, il se trouve sous "/usr/local/php/etc/" et "/usr/local/php/sbin/" 2. Sur la plateforme mac, il se trouve dans les répertoires "/etc/" et "/usr/bin/".

Quel est le chemin d'installation de php-fpm ?

1. Que sont fastcgi et php-fpm en php

Récemment, vous avez recherché et appris les performances de php ? factcgi et php-fpm, et j'ai constaté que je les comprenais très peu. On peut dire que je n'en savais presque rien. C'est assez effrayant d'y penser. J'ai décidé d'étudier cet aspect attentivement.

Référencement et étude des articles suivants :
1. Introduction, comparaison et données de performances de mod_php, mod_fastcgi et php-fpm
2. Nginx_replacement pratique

Comment présenter fastcgi et php-fpm étape par étape, je vais d'abord parler petit à petit de l'environnement de PHP. Pourquoi. Tout à coup, je sens que la vie est si fatiguante !

Parlons d'abord du serveur Web

php est un langage back-end né pour le Web. Bien sûr, nous, les chiens php, le savons mieux. PHP n'est donc qu'un langage back-end, il doit donc s'appuyer sur un serveur Web pour fournir des fonctions Web. Bien entendu, si d’autres langages back-end sont utilisés pour les applications Web, ils doivent également s’appuyer sur des serveurs Web. D'accord, le serveur Web est introduit depuis php, bien !

Alors, quels sont les serveurs Web courants ? Le chien PHP le plus couramment utilisé est Apache, et il en existe d'autres :

  • apache
  • nginx
  • IIS
  • lighttpd
  • tomcat

Fondamentalement, ceux ci-dessus, les plus couramment utilisés associés à php sont Apache et Nginx.

Utilisons d'abord Apache comme serveur Web comme exemple pour illustrer un accès php complet :

Quel est le chemin dinstallation de php-fpm ?

L'image explique très bien php Un flux d'accès Web complet graphique combinant la base de données MySQL avec Apache

mode mod_php

Ce qui précède indique clairement que php doit s'appuyer sur le serveur Web pour fournir des services fonctionnels Web. Voyons maintenant comment faire. devenir gay.

Celui que nous utilisons le plus est Apache. Alors rappelez-vous, comment Apache peut-il reconnaître le code php ? Est-il nécessaire d'ajouter ou de modifier les phrases suivantes dans le fichier de configuration Apache httpd.conf :

//加入以下2句
LoadModule php5_module D:/php/php5apache2_2.dll
AddType application/x-httpd-php .php

//将下面的
<IfModule dir_module>
    DirectoryIndex index.html
</IfModule>
//将其修改为:
<IfModule dir_module>
    DirectoryIndex index.html index.htm index.php index.phtml
</IfModule>

La configuration manuelle ci-dessus après l'installation de l'environnement php et apache sous Windows, l'installation du code source sous Linux est grossièrement configurée comme ceci :

./configure --with-mysql=/usr/local --with-apache=/usr/local/apache --enable-track-vars

Donc, de cette façon, leur essence commune est d'utiliser LoadModule pour charger php5_module, ce qui consiste à exécuter php en tant que sous-module d'Apache. Lorsqu'un fichier php est accédé via le Web, Apache appellera php5_module pour analyser le code php.

Alors, comment php5_module transmet-il les données à l'analyseur php pour analyser le code php ?

La réponse passe par sapi

Regardons une autre image pour parler en détail de la relation entre Apache, php et sapi :

Quel est le chemin dinstallation de php-fpm ?

D'après l'image ci-dessus, nous pouvons voir que sapi est un tel processus intermédiaire qui fournit une interface pour la communication externe, quelque peu similaire à socket Autorise PHP. pour interagir avec d'autres applications (apache, nginx, cli, etc.). PHP fournit de nombreux types de SAPI par défaut, notamment le module php5_module commun pour Apache et nginx, CGI, ISAPI pour IIS et Shell CLI.

Donc, le processus d'exécution de l'appel PHP ci-dessus est le suivant :

apache -> httpd -> php5_module -> sapi -> php

D'accord. Voyons Apache et PHP via php5_module !

Nous appelons ce mode de fonctionnement mod_phpmode

mode mod_fastcgi

Nous avons soigneusement mentionné ci-dessus que php et apache passent php5_module, et php5_module passe l'accès à php via sapi pour réaliser l'ensemble du processus de php web.

Sapi est également mentionné ci-dessus sapi est une interface unifiée fournie par php. Elle fournit php5_module et cgi pour que les serveurs Web puissent lier et analyser le code php. Le mode de chargement php5_module mentionné ci-dessus est appelé le mode mod_php.

Alors ! Dang Dang Dang ! Parlons bientôt du mode fastcgi. Hahahahaha, c'est trop inacceptable.

Ensuite, une autre façon de sapi de PHP est de fournir le mode cgi puisque cgi est relativement ancien, fastcgi est apparu pour le remplacer.

Alors, hé. Pas question, qu'est-ce que CGI déjà ?

CGI (Common Gateway Interface). CGI est une norme d'interface entre les applications externes (programmes CGI) et les serveurs Web. Il s'agit d'une procédure de transfert d'informations entre les programmes CGI et les serveurs Web. La spécification CGI permet aux serveurs Web d'exécuter des programmes externes et d'envoyer leur sortie aux navigateurs Web. CGI transforme le simple ensemble de documents hypermédia statiques du Web en un tout nouveau média interactif.

Ça fait mal de lire l'explication officielle. Pour faire simple, cgi est spécialement utilisé pour gérer les serveurs web. Lorsque le serveur Web reçoit une demande d'utilisateur, il soumettra la demande au programme cgi (fastcgi de php). Le programme cgi traitera (analysera php) en fonction des paramètres soumis dans la demande, puis générera une instruction HTML standard et renverra. au serveur Web, puis revenez au client, c'est ainsi que fonctionne normalement CGI.

L'avantage de cgi est qu'il est totalement indépendant de tout serveur et ne joue qu'un rôle d'intermédiaire. Fournit des interfaces pour Apache et PHP. Ils ont utilisé un câblage CGI pour compléter l'action gay. L’avantage est de minimiser l’association entre les deux et de les rendre plus indépendants.

Mais il y a une chose gênante à propos de cgi, c'est-à-dire que chaque requête Web aura un processus de démarrage et de sortie, qui est le mode fork-and-execute le plus critiqué. sera mort.

Alors. C'est à cette époque que fastcgi l'application voit le jour. Il est démarré tôt à l'avance et peut démarrer plusieurs modules cgi. Il continue de s'exécuter là-bas, en attendant les requêtes du Web, puis termine l'opération d'analyse de PHP pour générer du HTML pour le Web, et il ne se terminera pas et continuera. pour attendre la prochaine requête Web. De plus, le démarrage de ces modules CGI est contrôlable et supervisable. Cette technologie permet également d'exécuter le serveur Web et PHP sur différents hôtes pour évoluer massivement et améliorer la sécurité sans perte de productivité.

Alors maintenant, la plupart des systèmes d'exploitation sont en mode fastcgi. La mode cig s’est elle aussi progressivement retirée de la scène de l’histoire ! Lorsque nous disons cgi dans notre article, cela fait généralement référence à fastcgi.

Ce mode de fonctionnement s'appelle donc mod_fastcgi mode

Je parlerai de la façon d'utiliser le mode fastcgi pour connecter php et apache (ou nginx) dans le prochain paragraphe

Pour résumer : lorsque php est combiné avec apache ou ngix, sapi sera utilisé pour fournir 2 méthodes de connexion : mod_php和mod_fastcgi. Le mode mod_php installera le module php sous Apache pour l'exécuter, et les deux sont plus étroitement intégrés. Le mode mod_fastcgi est un processus intermédiaire. Une fois qu'Apache a introduit la requête de l'utilisateur, il l'envoie à fastcgi, puis se connecte à php pour terminer l'accès.

Représentez graphiquement ces deux modes

mode mod_php

le mode mod_php installe le module php dans Apache, donc chaque fois qu'Apache termine la requête, un message sera généré Processus, ce Le processus comprend complètement divers calculs et autres opérations de PHP.

Quel est le chemin dinstallation de php-fpm ?

Sur l'image, nous pouvons clairement voir que chaque fois qu'Apache reçoit une demande, un processus sera généré pour se connecter à php afin de compléter la demande via sapi. , S'il y a trop d'utilisateurs et trop d'utilisateurs simultanés, le serveur ne pourra pas le supporter.

De plus, lorsque mod_php est compilé dans apache, il est difficile de déterminer s'il s'agit d'un problème avec PHP ou Apache lorsqu'un problème survient.

mode mod_fastcgi

le mode mod_fastcgi est tout le contraire. Fastcgi est une entité indépendante d'Apache et de php. Elle démarre avec Apache, génère plusieurs modules cig et attend les requêtes d'Apache. :

Quel est le chemin dinstallation de php-fpm ?

Sur la photo, fastcgi a été démarré tôt et il attend tranquillement. La requête httpd envoyée par Apache est immédiatement reçue et est envoyée en appelant sapi. , terminez l'opération. Et je n'arrêterai pas. Cela peut gérer des requêtes simultanées à grande échelle, car le serveur Web a moins de travail à faire, il peut donc traiter la requête suivante plus rapidement, ce qui améliore considérablement la simultanéité.

Parce qu'apache et php sont indépendants. S’il y a un problème, il est facile de localiser l’endroit où se situe le problème. C’est l’une des raisons pour lesquelles ce modèle est populaire.

php-fpm

J'ai fait beaucoup de choses et je veux enfin parler de php-fpm. ^....^

Allons droit au but et parlons de ce à quoi sert php-fpm. Il est spécialement conçu pour assister le mode mode_fastcgi.

Hmm. Bon, maintenant que nous savons ce qu'il fait, revenons au mode mode_fastcgi. Grâce aux explications précédentes, j'ai déjà compris à quoi ressemble ce mode.

fastcgi est indépendant de la plate-forme et du langage. Tant qu'un langage est implémenté en fonction de son interface, il peut réaliser la capacité fastcgi de son propre langage et communiquer avec le serveur Web.

PHP-CGI est le gestionnaire FastCGI implémenté par PHP.

Bien qu'il s'agisse d'un produit officiel de PHP et qu'il soit livré avec, il n'est pas puissant du tout, les performances sont trop médiocres, et il est également très gênant et impersonnel, se reflétant principalement dans :

  1. Après que php-cgi ait modifié la configuration de php.ini, vous devez redémarrer php-cgi pour que le nouveau php-ini prenne effet, et un redémarrage en douceur n'est pas possible.
  2. Tuez directement le processus php-cgi et php ne pourra pas s'exécuter.

Les deux problèmes ci-dessus ont causé des maladies à de nombreuses personnes pendant longtemps, c'est pourquoi de nombreuses personnes utilisent encore la méthode mode_php.

直到 2004年(确定是这么早吗?)一个叫 Andrei Nigmatulin的屌丝发明了PHP-FPM ,这神器的出现就彻底打破了这种局面,这是一个PHP专用的fastcgi管理器,它很爽的克服了上面2个问题,而且,还表现在其他方面更表现强劲. 请戳官网

我擦,这一篇貌似又瞎比比的说超时了啊。好吧。那windows和linux下安装配置php-fpm就下一节来说吧。反正我已经已经把php-fpm和fastcgi给讲清楚了。

===============================================================================

2、php-fpm的安装和启动

在前面我学习过了php中的mod_php模式mode_fastcgi和php-fpm模式:地址,中大致的讲述了几种模式的区别,也明白了php-fpm是fastcgi模式的管理器。今天就来看下php如何安装php-fpm,以及运行。

安装 php-fpm

我的机器是centos 6.2 之前就已经安装过了php 5.4.11,PHP在 5.3.3 之后已经讲php-fpm写入php源码核心了。所以已经不需要另外下载了。我这里是5.4.11所以就可以直接用。

由于我php已经安装好了,而且之前编译的时候没有带上fpm模式,所以我必须找到源码重新编译一下:

要想使php支持php-fpm,只需要在编译的时候带上 --enable-fpm 就可以了。

所以,我需要找到之前的编译参数, 后面加上--enable-fpm ,重新编译下就可以了。之前就讲过,有2种方式可以找到之前的编译参数:

  1. 在源码 /lamp/php-5.4.11/中找到 config.nice,这个就是之前的编译参数
  2. 在php.ini配置文件中找到Configure相关的配置 :
    /usr/local/php/bin/php -i |grep 'Configure'

好,我们开始,找到之前的编译参数:

[root@localhost /]# cd /lamp/php-5.4.11 & vi config.nice
&#39;./configure&#39; \
&#39;--prefix=/usr/local/php&#39; \
&#39;--with-config-file-path=/usr/local/php/etc/&#39; \
&#39;--with-apxs2=/usr/local/apache/bin/apxs&#39; \
&#39;--with-mysql=/usr/local/mysql/&#39; \
&#39;--with-libxml-dir=/usr/local/libxml2/&#39; \
&#39;--with-png-dir=/usr/local/libpng/&#39; \
&#39;--with-jpeg-dir=/usr/local/jpeg8/&#39; \
&#39;--with-freetype-dir=/usr/local/freetype/&#39; \
&#39;--with-gd=/usr/local/gd/&#39; \
&#39;--with-zlib-dir=/usr/local/zlib/&#39; \
&#39;--with-mcrypt=/usr/local/libmcrypt/&#39; \
&#39;--with-mysqli=/usr/local/mysql/bin/mysql_config&#39; \
&#39;--enable-soap&#39; \
&#39;--enable-mbstring=all&#39; \
&#39;--enable-sockets&#39; \

加上--enable-fpm后,重新编译:

[root@localhost /]# cd /lamp/php-5.4.11
[root@localhost php-5.4.11]# &#39;./configure&#39; \
    &#39;--prefix=/usr/local/php&#39; \
    &#39;--with-config-file-path=/usr/local/php/etc/&#39; \
    &#39;--with-apxs2=/usr/local/apache/bin/apxs&#39; \
    &#39;--with-mysql=/usr/local/mysql/&#39; \
    &#39;--with-libxml-dir=/usr/local/libxml2/&#39; \
    &#39;--with-png-dir=/usr/local/libpng/&#39; \
    &#39;--with-jpeg-dir=/usr/local/jpeg8/&#39; \
    &#39;--with-freetype-dir=/usr/local/freetype/&#39; \
    &#39;--with-gd=/usr/local/gd/&#39; \
    &#39;--with-zlib-dir=/usr/local/zlib/&#39; \
    &#39;--with-mcrypt=/usr/local/libmcrypt/&#39; \
    &#39;--with-mysqli=/usr/local/mysql/bin/mysql_config&#39; \
    &#39;--enable-soap&#39; \
    &#39;--enable-mbstring=all&#39; \
    &#39;--enable-sockets&#39; \
    &#39;--enable-fpm&#39;
[root@localhost php-5.4.11] make && make install

启动 php-fpm

安装完成之后,我们尝试着启动:

启动命令是:

/usr/local/php/sbin/php-fpm

报错了:

[26-Feb-2015 15:39:55] ERROR: failed to open configuration file &#39;/usr/local/php/etc/php-fpm.conf&#39;: No such file or directory (2)
[26-Feb-2015 15:39:55] ERROR: failed to load configuration file &#39;/usr/local/php/etc/php-fpm.conf&#39;
[26-Feb-2015 15:39:55] ERROR: FPM initialization failed

错误信息说找不到 php-fpm.conf

哦,原来是php-fpm.conf还没有,我们到 /usr/local/php/etc目录下将php-fpm.conf.default拷贝也一份成php-fpm.conf

 cd /usr/local/php/etc/cp php-fpm.conf.default php-fpm.conf

编辑一下这个配置文件:

vim php-fpm.conf

pid = run/php-fpm.pid
user = www
group = www

再次尝试启动:

/usr/local/php/sbin/php-fpm

再次报错说www 用户不存在:

[26-Feb-2015 15:57:38] ERROR: [pool www] cannot get uid for user &#39;www&#39;
[26-Feb-2015 15:57:38] ERROR: FPM initialization failed

好,那我们新建www 用户组:

 groupadd wwwuseradd -g www www

再次启动:

/usr/local/php/sbin/php-fpm

没有任何的输出,表示成功了!!!

php-fpm占用的是9000端口,我们查看下进程:

[root@localhost php-5.4.11]# ps -ef|grep php-fpm
root      1377  1231  0 11:19 pts/1    00:00:00 grep php-fpm
root     29249     1  0 06:22 ?        00:00:00 php-fpm: master process (/usr/local/php/etc/php-fpm.conf)
www      29250 29249  0 06:22 ?        00:00:00 php-fpm: pool www
www      29251 29249  0 06:22 ?        00:00:00 php-fpm: pool www
root     32132  6158  0 08:25 pts/2    00:00:00 vi php-fpm.conf
[root@localhost php-5.4.11]# netstat -tnl | grep 9000
tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      
[root@localhost php-5.4.11]#

好,安装和启动都OK了。

开机启动 php-fpm

之前接说过php-fpm是独立于web服务器和php之前的一层服务器,所以,我们需要开机启动它

开机启动的配置文件是:/etc/rc.local ,加入 /usr/local/php/sbin/php-fpm 即可

[root@localhost init]# vi /etc/rc.local

      1 #!/bin/sh
      2 #
      3 # This script will be executed *after* all the other init scripts.
      4 # You can put your own initialization stuff in here if you don&#39;t
      5 # want to do the full Sys V style init stuff.
      6 
      7 touch /var/lock/subsys/local
      8 /usr/local/apache/bin/apachectl start
      9 /usr/local/bin/redis-server /etc/redis.conf
     10 /usr/local/php/sbin/php-fpm

光安装好php-fpm也是没用的,得配合web服务器使用,下一节,我要学习nginx的安装,以及nginx连接php-fpm来使用php。

重启 php-fpm

我们在新安装扩展后,是需要重新php-fpm的,已使扩展生效。

最简单粗暴的重新php-fpm的方式是:

先找到php-fpm的进程号,kill 掉,再用/usr/local/php/sbin/php-fpm 这样启动。

其实还有更多温和的方法,就是使用信号

INT, TERM 立刻终止
QUIT 平滑终止
USR1 重新打开日志文件
USR2 平滑重载所有worker进程并重新载入配置和二进制模块

示例:

php-fpm 关闭:

kill -INT `cat /usr/local/php/var/run/php-fpm.pid`

php-fpm 重启:

kill -USR2 `cat /usr/local/php/var/run/php-fpm.pid`

===============================================================================

3、php-fpm的配置和优化

我在前面几篇中,很详细的讲述了php-fpm的各种介绍,和安装。今天来看一下它的配置文件php-fpm的各种配置以及一些常见的优化。

php-fpm的安装目录

下面是我的平时的环境搭建php的各种安装目录,大家的基本也差不多。

centos等linux平台

/usr/local/php/php
/usr/local/php/etc/php.ini
/usr/local/php/sbin/php-fpm
/usr/local/php/etc/php-fpm.conf

mac平台

/usr/bin/php
/etc/php.ini
/usr/bin/php-fpm
/etc/php-fpm.conf

由于我开发以Mac为主,所以就用Mac的环境配置来学习。

php-fpm配置详解

这是搜索的一份还算算比较详细的php-fpm.conf配置详解,我会针对性的修改下,当然php手册上也有详细的讲解:http://php.net/manual/zh/install.fpm.configuration.php

pid = /usr/local/var/run/php-fpm.pid
#pid设置,一定要开启,上面是Mac平台的。默认在php安装目录中的var/run/php-fpm.pid。比如centos的在: /usr/local/php/var/run/php-fpm.pid

error_log  = /usr/local/var/log/php-fpm.log
#错误日志,上面是Mac平台的,默认在php安装目录中的var/log/php-fpm.log,比如centos的在: /usr/local/php/var/log/php-fpm.log

log_level = notice
#错误级别. 上面的php-fpm.log纪录的登记。可用级别为: alert(必须立即处理), error(错误情况), warning(警告情况), notice(一般重要信息), debug(调试信息). 默认: notice.

emergency_restart_threshold = 60
emergency_restart_interval = 60s
#表示在emergency_restart_interval所设值内出现SIGSEGV或者SIGBUS错误的php-cgi进程数如果超过 emergency_restart_threshold个,php-fpm就会优雅重启。这两个选项一般保持默认值。0 表示 &#39;关闭该功能&#39;. 默认值: 0 (关闭).

process_control_timeout = 0
#设置子进程接受主进程复用信号的超时时间. 可用单位: s(秒), m(分), h(小时), 或者 d(天) 默认单位: s(秒). 默认值: 0.

daemonize = yes
#后台执行fpm,默认值为yes,如果为了调试可以改为no。在FPM中,可以使用不同的设置来运行多个进程池。 这些设置可以针对每个进程池单独设置。

listen = 127.0.0.1:9000
#fpm监听端口,即nginx中php处理的地址,一般默认值即可。可用格式为: &#39;ip:port&#39;, &#39;port&#39;, &#39;/path/to/unix/socket&#39;. 每个进程池都需要设置。如果nginx和php在不同的机器上,分布式处理,就设置ip这里就可以了。

listen.backlog = -1
#backlog数,设置 listen 的半连接队列长度,-1表示无限制,由操作系统决定,此行注释掉就行。backlog含义参考:http://www.3gyou.cc/?p=41

listen.allowed_clients = 127.0.0.1
#允许访问FastCGI进程的IP白名单,设置any为不限制IP,如果要设置其他主机的nginx也能访问这台FPM进程,listen处要设置成本地可被访问的IP。默认值是any。每个地址是用逗号分隔. 如果没有设置或者为空,则允许任何服务器请求连接。

listen.owner = www
listen.group = www
listen.mode = 0666
#unix socket设置选项,如果使用tcp方式访问,这里注释即可。

user = www
group = www
#启动进程的用户和用户组,FPM 进程运行的Unix用户, 必须要设置。用户组,如果没有设置,则默认用户的组被使用。

pm = dynamic 
#php-fpm进程启动模式,pm可以设置为static和dynamic和ondemand
#如果选择static,则进程数就数固定的,由pm.max_children指定固定的子进程数。

#如果选择dynamic,则进程数是动态变化的,由以下参数决定:
pm.max_children = 50 #子进程最大数
pm.start_servers = 2 #启动时的进程数,默认值为: min_spare_servers + (max_spare_servers - min_spare_servers) / 2
pm.min_spare_servers = 1 #保证空闲进程数最小值,如果空闲进程小于此值,则创建新的子进程
pm.max_spare_servers = 3 #,保证空闲进程数最大值,如果空闲进程大于此值,此进行清理

pm.max_requests = 500
#设置每个子进程重生之前服务的请求数. 对于可能存在内存泄漏的第三方模块来说是非常有用的. 如果设置为 &#39;0&#39; 则一直接受请求. 等同于 PHP_FCGI_MAX_REQUESTS 环境变量. 默认值: 0.

pm.status_path = /status
#FPM状态页面的网址. 如果没有设置, 则无法访问状态页面. 默认值: none. munin监控会使用到

ping.path = /ping
#FPM监控页面的ping网址. 如果没有设置, 则无法访问ping页面. 该页面用于外部检测FPM是否存活并且可以响应请求. 请注意必须以斜线开头 (/)。

ping.response = pong
#用于定义ping请求的返回相应. 返回为 HTTP 200 的 text/plain 格式文本. 默认值: pong.

access.log = log/$pool.access.log
#每一个请求的访问日志,默认是关闭的。

access.format = "%R - %u %t \"%m %r%Q%q\" %s %f %{mili}d %{kilo}M %C%%"
#设定访问日志的格式。

slowlog = log/$pool.log.slow
#慢请求的记录日志,配合request_slowlog_timeout使用,默认关闭

request_slowlog_timeout = 10s
#当一个请求该设置的超时时间后,就会将对应的PHP调用堆栈信息完整写入到慢日志中. 设置为 &#39;0&#39; 表示 &#39;Off&#39;

request_terminate_timeout = 0
#设置单个请求的超时中止时间. 该选项可能会对php.ini设置中的&#39;max_execution_time&#39;因为某些特殊原因没有中止运行的脚本有用. 设置为 &#39;0&#39; 表示 &#39;Off&#39;.当经常出现502错误时可以尝试更改此选项。

rlimit_files = 1024
#设置文件打开描述符的rlimit限制. 默认值: 系统定义值默认可打开句柄是1024,可使用 ulimit -n查看,ulimit -n 2048修改。

rlimit_core = 0
#设置核心rlimit最大限制值. 可用值: &#39;unlimited&#39; 、0或者正整数. 默认值: 系统定义值.

chroot =
#启动时的Chroot目录. 所定义的目录需要是绝对路径. 如果没有设置, 则chroot不被使用.

chdir =
#设置启动目录,启动时会自动Chdir到该目录. 所定义的目录需要是绝对路径. 默认值: 当前目录,或者/目录(chroot时)

catch_workers_output = yes
#重定向运行过程中的stdout和stderr到主要的错误日志文件中. 如果没有设置, stdout 和 stderr 将会根据FastCGI的规则被重定向到 /dev/null . 默认值: 空.

当然还有一些无关紧要的设置,用到了再说吧。

一些重要的设置

php-fpm进程分配

在之前的文章中就说过了。在fasgcgi模式下,php会启动多个php-fpm进程,来接收nginx发来的请求,那是不是进程越多,速度就越快呢?这可不一定!得根据我们的机器配置和业务量来决定。

我们先来看下,设定进程的配置在哪里?

pm = static | dynamic | ondemand

pm可以设置成这样3种,我们用的最多的就上前面2种。

pm = static 模式

pm = static 表示我们创建的php-fpm子进程数量是固定的,那么就只有pm.max_children = 50这个参数生效。你启动php-fpm的时候就会一起全部启动51(1个主+50个子)个进程,颇为壮观。

pm = dynamic 模式

pm = dynamic模式,表示启动进程是动态分配的,随着请求量动态变化的。他由 pm.max_childrenpm.start_serverspm.min_spare_serverspm.max_spare_servers 这几个参数共同决定。

上面已经讲过,这里再重申一下吧:

pm.max_children = 50 是最大可创建的子进程的数量。必须设置。这里表示最多只能50个子进程。

pm.start_servers = 20 随着php-fpm一起启动时创建的子进程数目。默认值:min_spare_servers + (max_spare_servers - min_spare_servers) / 2。这里表示,一起启动会有20个子进程。

pm.min_spare_servers = 10
设置服务器空闲时最小php-fpm进程数量。必须设置。如果空闲的时候,会检查如果少于10个,就会启动几个来补上。

pm.max_spare_servers = 30
设置服务器空闲时最大php-fpm进程数量。必须设置。如果空闲时,会检查进程数,多于30个了,就会关闭几个,达到30个的状态。

到底选择static还数dynamic?

很多人恐惧症来袭,不知道选什么好?

一般原则是:动态适合小内存机器,灵活分配进程,省内存。静态适用于大内存机器,动态创建回收进程对服务器资源也是一种消耗。

如果你的内存很大,有8-20G,按照一个php-fpm进程20M算,100个就2G内存了,那就可以开启static模式。如果你的内存很小,比如才256M,那就要小心设置了,因为你的机器里面的其他的进程也算需要占用内存的,所以设置成dynamic是最好的,比如:pm.max_chindren = 8, 占用内存160M左右,而且可以随时变化,对于一半访问量的网站足够了。

慢日志查询

我们有时候会经常饱受500,502问题困扰。当nginx收到如上错误码时,可以确定后端php-fpm解析php出了某种问题,比如,执行错误,执行超时。

这个时候,我们是可以开启慢日志功能的。

slowlog = /usr/local/var/log/php-fpm.log.slow
request_slowlog_timeout = 15s

当一个请求该设置的超时时间15秒后,就会将对应的PHP调用堆栈信息完整写入到慢日志中。

php-fpm慢日志会记录下进程号,脚本名称,具体哪个文件哪行代码的哪个函数执行时间过长:

[21-Nov-2013 14:30:38] [pool www] pid 11877
script_filename = /usr/local/lnmp/nginx/html/www.quancha.cn/www/fyzb.php
[0xb70fb88c] file_get_contents() /usr/local/lnmp/nginx/html/www.quancha.cn/www/fyzb.php:2

通过日志,我们就可以知道第2行的file_get_contents 函数有点问题,这样我们就能追踪问题了。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn