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

在 linux 中,nginx 服务器和 php-fpm 能够经过 tcp socket 和 unix socket 两种方式实现。 php

一下内容转自:https://blog.csdn.net/qq624202120/article/details/60957634linux

tcp socket nginx

容许经过网络进程之间的通讯,也能够经过loopback进行本地进程之间通讯。缓存

unix socket 服务器

容许在本地运行的进程之间进行通讯。网络

 

对比分析:php7

 

从上面的图片能够看,unix socket 减小了没必要要的 tcp 开销,而 tcp 须要通过 loopback,还要申请临时端口和 tcp 相关资源。可是,unix socket 高并发时候不稳定,链接数爆发时,会产生大量的长时缓存,在没有面向链接协议的支撑下,大数据包可能会直接出错不返回异常。tcp这样的面向链接的协议,多少能够保证通讯的正确性和完整性。 并发

 

如何选择 负载均衡

若是是在同一台服务器上运行的 nginx 和 php-fpm,并发量不超过1000,选择 unix socket,由于是本地,能够避免一些检查操做(路由等),所以更快,更轻。 若是面临高并发业务,选择使用更可靠的 tcp socket,以负载均衡、内核优化等运维手段维持效率。 运维

 

nginx 和 php-fpm 使用 unix socket

将sock文件放在/dev/shm目录下,使用的内存读写更快。

1 # cd /dev/shm
2 touch php7.0-fpm.sock 
3 chown www-data:www-data php7.0-fpm.sock
4 chmod 777 php7.0-fpm.sock

php-fpm.conf

1 # vi /etc/php/7.0/fpm/pool.d/www.conf
2 listen= /dev/shm/php7.0-fpm.sock
3 listen.owner = www-data
4 listen.group = www-data

nginx location 配置

1   location ~* \.php$ {
2     fastcgi_pass unix:/dev/shm/php7.0-fpm.sock;
3     fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
4     include /etc/nginx/fastcgi_params;
5   }

 

提升nginx和php-fpm使用的 unix socket稳定性(单机能力有限)

1.修改内核参数

 1 net.unix.max_dgram_qlen = 4096 2 net.core.netdev_max_backlog = 4096 3 net.core.somaxconn = 4096 

2.提升 backlog

backlog 默认位128,1024这个值最好换算成本身正常的QPS。

1 nginx.conf
2 server{
3   listen 80 default backlog=1024;
4 }
5 
6 php-fpm.conf
7 listen.backlog = 1024
8 
9 ---------------------

3.增长 sock 文件和 php-fpm 实例

在 /dev/shm 新建一个 sock 文件,在 nginx 中经过 upstream 魔抗将请求负载均衡到两个 sock 文件, 而且将两个 sock 文件分别对应到两套 php-fpm 实例上。

相关文章
相关标签/搜索