nginx和php-fpm通信的两种方式

简述

在linux中,nginx服务器和php-fpm可以通过tcp socket和unix socket两种方式实现。

unix socket是一种终端,可以使同一台操作系统上的两个或多个进程进行数据通信。这种方式需要再nginx配置文件中填写php-fpm的pid文件位置,效率要比tcp socket高。

tcp socket的优点是可以跨服务器,当nginx和php-fpm不在同一台机器上时,只能使用这种方式

配置方法

tcp socket

tcp socket通信方式,需要在nginx配置文件中填写php-fpm运行的ip地址和端口号。

location ~ \.php$ {
    include fastcgi_params;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;;
    fastcgi_pass 127.0.0.1:9000;
    fastcgi_index index.php;
}

unix socket

unix socket通信方式,需要在nginx配置文件中填写php-fpm运行的pid文件地址

location ~ \.php$ { include fastcgi_params;

      fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;;

       fastcgi_pass unix:/var/run/php5-fpm.sock;

       fastcgi_index index.php; }

php-fpm的运行端口号和socket文件的地址都是在php-fpm.conf中配置的。 
php-fpm.conf文件在php安装文件的/etc目录下, 
比如你的php安装在/opt/php目录,则应该是/opt/php/php-fpm.conf。

nginx和php-fpm通信的两种方式_第1张图片

 

 

通过注释可以看到,php-fpm的listen指令可以通过五种方式处理FastCGI请求,分别是: 
1. ipv4:端口号 
2. ipv6:端口号 
3. port相当于 0.0.0.0:port,本机所有ipv4对应的端口号 
4. [::]:port,包括ipv4和ipv6 
5. unix socket文件

直接配置使用unix socket文件之后,会遇到access deny的问题,由于socket文件本质上还是一个文件,存在权限控制问题,默认由root用户创建,

因此nginx进程无权限访问,应该配置如下命令:

nginx和php-fpm通信的两种方式_第2张图片

可以配置nginx和php-fpm都是用www用户,这样就不会存在权限问题,当然也可以创建不同的用户,然后加入同一个组,便于分配权限。

关于更多linux权限控制,可以参考 http://blog.csdn.net/koastal/article/details/52447735

你可能感兴趣的:(nginx)