nginx和php-fpm 是使用 tcp socket 仍是 unix socket ?

tcp socket

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

unix socket

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

分析

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

个人选择

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

nginx和php-fpm 使用unix socket

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

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

php-fpm 配置服务器

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

nginx server块配置网络

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

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

1.修改内核参数php7

net.unix.max_dgram_qlen = 4096
net.core.netdev_max_backlog = 4096
net.core.somaxconn = 4096

2.提升backlog
backlog默认位128,1024这个值最好换算成本身正常的QPS。并发

nginx.conf
server{
  listen 80 default backlog=1024;
}

php-fpm.conf
listen.backlog = 1024

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

相关文章
相关标签/搜索