nginx通过TCP以及unix-domain-socket连接fastcgi方式对比

本文对比了Nginx与FastCGI通过TCP和Unix Domain Socket两种方式进行通信的性能表现。测试结果显示,在服务器压力较大时,使用Unix Domain Socket能够提供更好的性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对于nginx连接fastcgi的两种不同方式做了测试,结果如下。

Tcp是使用TCP端口连接127.0.0.1:9000

Socket是使用unix domain socket连接套接字/dev/shm/php-cgi.sock

测试机是个1核的centos5.4,2用户并发时系统资源消耗50%左右,10用户资源就跑得很满了。

结论是在服务器压力不大的情况下,tcp和socket差别不大,但在压力比较满的时候,用套接字方式,效果确实比较好。 



2users 10users
nginx/1.2.9 + PHP 5.2.5 tcp 1060 1294
nginx/1.2.9 + PHP 5.2.5 socket 997 1487
nginx/1.2.9 + PHP 5.3.10 tcp 906 1082
nginx/1.2.9 + PHP 5.3.10 socket 880 1247


下面是配置方法

平时大家配置的nginx连接fastcgi的方式都是tcp的,现在使用一种速度更快的方法unix domain socket来完成:

一:首先建立/dev/shm/php-cgi.sock文件,然后将之改所有者改为nginx(与 nginx的用户一致):

#touch /dev/shm/php-cgi.sock

#chown nginx:nginx /dev/shm/php-cgi.sock

二:编辑 nginx.conf和业务conf

修改:
# fastcgi_pass 127.0.0.1:9000;
fastcgi_pass unix:/dev/shm/php-cgi.sock;

三:在php-fpm.conf中修改配置为:

PHP5.2.5:

#127.0.0.1:9000
/dev/shm/php-cgi.sock

PHP5.3.10:

;listen = 127.0.0.1:9000
listen = /dev/shm/php-cgi.sock

重启php-fpm与nginx就可以了,ls -all查看/dev/shm/php-cgi.sock由普通文件变成s开头的unix套接字








nginx 和 php-fpm 通信使用unix socket还是TCP,及其配置


前言

nginx和fastcgi的通信方式有两种,一种是TCP的方式,一种是unix socke方式。两种方式各有优缺点,这里先给出两种的配置方法,然后再对性能、安全性等做出总结。

配置指南

TCP配置方式

TCP通信配置起来很简单,三步即可搞定

第一步,编辑 /etc/nginx/conf.d/你的站点配置文件(如果使用的默认配置文件,修改/etc/nginx/sites-available/default)

将fastcgi_pass参数修改为127.0.0.1:9000,像这样:

 第二步,编辑php-fpm配置文件 /etc/php5/fpm/pool.d/www.conf

将listen参数修改为127.0.0.1:9000,像这样:

 第三步,重启php-fpm,重启nginx

 

unix socket配置方式

unix socket其实严格意义上应该叫unix domain socket,它是*nix系统进程间通信(IPC)的一种被广泛采用方式,以文件(一般是.sock)作为socket的唯一标识(描述符),需要通信的两个进程引用同一个socket描述符文件就可以建立通道进行通信了。

配置需要五步

第一步,决定你的socket描述符文件的存储位置。

可以放在系统的任意位置,如果想要更快的通信速度,可以放在/dev/shm下面,这个目录是所谓的tmpfs,是RAM可以直接使用的区域,所以,读写速度都会很快。

决定了文件位置,就要修改文件的权限了,要让nginx和php-fpm对它都有读写的权限,可以这样:

 第二步,修改php-fpm配置文件/etc/php5/fpm/pool.d/www.conf

将listen参数修改为/dev/shm/fpm-cgi.sock,像这样:

 将listen.backlog参数改为-1,内存积压无限大,默认是128,并发高了之后就会报错

 第三步,修改nginx站点配置文件

将fastcgi_pass参数修改为unix:/dev/shm/fpm-cgi.sock,像这样:

第四步,修改/etc/sysctl.conf 文件,提高内核级别的并发连接数(这个系统级的配置文件我也不是特别熟悉,参考的是这篇博客:《Php-fpm TcpSocket vs UnixSocket》)

第五步, 重启nginx和php-fpm服务(最好先重启php-fpm再重启nginx)

 

两种通信方式的分析和总结

从原理上来说,unix socket方式肯定要比tcp的方式快而且消耗资源少,因为socket之间在nginx和php-fpm的进程之间通信,而tcp需要经过本地回环驱动,还要申请临时端口和tcp相关资源。

当然还是从原理上来说,unix socket会显得不是那么稳定,当并发连接数爆发时,会产生大量的长时缓存,在没有面向连接协议支撑的情况下,大数据包很有可能就直接出错并不会返回异常。而TCP这样的面向连接的协议,多少可以保证通信的正确性和完整性。

当然以上主要是半懂不懂的理论分析加主观臆测,具体的差别还是要通过测试数据来说话,以后有空,会进行这方面的测试。从网上别人博客的测试数据,我的理论分析差不多是对的。至于你选择哪种方式,我只能说“鱼和熊掌不可兼得也”,通过高超的运维和配置技巧,在性能和稳定性上做一个平衡吧。

 

说说我的选择

其实,如果nginx做要做负载均衡的话,根本也不要考虑unix socket的方式了,只能采用TCP的方式。现在我的小站没有那么高的并发量,所以就用unix socket了,以后如果有了高并发业务,再进行一些参数调整即可应付,如果真要是无法支撑,那只能做负载均衡了,到时候自然会选择TCP方式。


<think>好的,我需要解释FastCGI如何使用socket与Lighttpd通信。首先,我得确认用户了解基本概念,比如FastCGI是什么,socket通信的类型。可能用户已经知道这些,但作为介绍的一部分,还是需要简要提及。 接下来,要区分Unix domain sockets和TCP sockets的区别。用户可能想知道为什么选择其中一种方式,以及各自的优缺点。需要解释它们的应用场景,比如Unix socket在本地通信效率更高,而TCP适用于远程或容器环境。 然后,具体配置步骤是关键。用户需要明确的步骤指导如何在Lighttpd中配置FastCGI使用socket。这里要确保语法正确,给出示例配置片段,并解释每个参数的作用,比如bin-path、socket、check-local等。需要注意路径和权限问题,这是实际配置中常见的坑点。 另外,权限设置是一个重要但容易被忽视的部分。需要提醒用户修改socket文件的权限,确保Lighttpd进程有访问权限,可能涉及chmod和chown命令。这部分需要详细说明,避免用户配置后出现权限错误。 性能调优部分,可以比较Unix socketTCP socket的性能差异,帮助用户根据实际情况选择。同时,提到max-procs和bin-environment等参数的作用,让用户了解如何优化FastCGI进程的管理。 可能的问题排查也是必要的。比如socket文件不存在、权限问题、进程未启动等,给出对应的解决建议。这部分能帮助用户在遇到问题时快速定位和解决。 最后,总结使用socket的优势,强调安全性、性能和资源占用。这样用户能有一个全面的理解,知道为什么选择socket通信方式,以及如何正确配置和维护。 整个过程中,需要保持语言简洁明了,结构清晰,步骤详细。避免使用过于专业的术语,或者在必要时解释术语。同时,通过示例配置和命令,让用户可以直接参考应用,提升实用性。</think>### FastCGI 使用 Unix Socket 与 Lighttpd 通信的原理与配置 FastCGI 是一种高性能的 CGI(通用网关接口)协议,允许 Web 服务器(如 Lighttpd)与外部程序(如 PHP/Python)高效通信。通过 **Unix Domain Socket**(文件系统 socket)而非 TCP 端口进行通信,可减少网络开销并提升安全性。以下是详细解析: --- #### 一、Unix Socket vs. TCP Socket | 类型 | Unix Domain Socket | TCP Socket | |-------------------|----------------------------------------|-------------------------| | **通信范围** | 同一台机器上的进程间通信 | 跨机器或本地进程通信 | | **性能** | 无网络协议栈开销,延迟更低 | 需要经过网络协议栈 | | **安全性** | 通过文件系统权限控制访问 | 依赖防火墙/IP白名单 | | **适用场景** | 本地服务(如 PHP-FPM 与 Web 服务器) | 分布式服务或容器环境 | --- #### 二、Lighttpd 配置 FastCGI + Unix Socket ##### 1. **配置 Lighttpd 支持 FastCGI** 修改 Lighttpd 配置文件(通常为 `/etc/lighttpd/lighttpd.conf`),添加以下内容: ```nginx server.modules += ("mod_fastcgi") # 启用 FastCGI 模块 fastcgi.server = ( ".php" => (( "bin-path" => "/usr/bin/php-cgi", # PHP-FPM 的路径(如果使用 PHP-CGI) "socket" => "/var/run/php-fpm.sock", # 指定 Unix Socket 文件路径 "check-local" => "disable", # 禁止 Lighttpd 直接处理 PHP 文件 "max-procs" => 4, # 最大进程数 "bin-environment" => ( # 环境变量(可选) "PHP_FCGI_CHILDREN" => "4" ) )) ) ``` ##### 2. **配置 PHP-FPM 使用 Unix Socket** 编辑 PHP-FPM 配置文件(如 `/etc/php-fpm.d/www.conf`): ```ini [www] listen = /var/run/php-fpm.sock # 与 Lighttpd 的 socket 路径一致 listen.owner = www-data # socket 文件所有者(需与 Lighttpd 运行用户一致) listen.group = www-data listen.mode = 0660 # 文件权限 ``` --- #### 三、关键步骤与权限设置 1. **创建 Socket 文件目录**: ```bash sudo mkdir -p /var/run/ sudo chown www-data:www-data /var/run/php-fpm.sock # 确保 Lighttpd 和 PHP-FPM 有权限访问 ``` 2. **重启服务**: ```bash sudo systemctl restart lighttpd php-fpm ``` 3. **验证 Socket 通信**: ```bash sudo lsof -U | grep php-fpm.sock # 查看 socket 是否被正确监听 ``` --- #### 四、性能调优建议 1. **选择 Unix Socket**: 本地服务优先使用 Unix Socket,避免 TCP 三次握手和网络延迟。 2. **调整进程数**: - `max-procs`:控制 Lighttpd 启动的 FastCGI 进程数量。 - `PHP_FCGI_CHILDREN`:控制每个 FastCGI 进程的子进程数(需根据服务器内存调整)。 3. **内核参数优化**(可选): ```bash # 提高 socket 队列长度 sysctl -w net.core.somaxconn=65535 ``` --- #### 五、常见问题排查 | 问题现象 | 可能原因 | 解决方案 | |--------------------------|--------------------------|-----------------------------------| | **502 Bad Gateway** | Socket 文件未创建 | 检查 PHP-FPM 是否运行,权限是否正确 | | **Permission denied** | Socket 文件权限错误 | 运行 `chmod 0660 /var/run/php-fpm.sock` | | **No input file specified** | `check-local` 未禁用 | 确认配置中 `check-local => "disable"` | --- #### 六、总结 - **优势**: Unix Socket 在本地通信中性能更高、资源占用更低,且通过文件系统权限实现安全隔离。 - **适用场景**: Lighttpd + PHP/Python 等本地服务的部署,尤其适合高并发场景。 - **扩展性**: 若需跨服务器通信(如容器化部署),可切换为 TCP Socket(配置 `listen = 127.0.0.1:9000`)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值