IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> FD_SETSIZE不够问题排查 -> 正文阅读

[PHP知识库]FD_SETSIZE不够问题排查

升级php 7.4的时候发现有warning报错,报错内容大致是

You MUST recompile PHP with a larger value of FD_SETSIZE....

下载 php 7.4.16 源码进行排查。

grep "You MUST recompile PHP with a larger value" -rn *

找到报错的位置
main/network.c:1174: “You MUST recompile PHP with a larger value of FD_SETSIZE.\n”
代码片段如下

PHPAPI void _php_emit_fd_setsize_warning(int max_fd)
{
#ifdef PHP_WIN32
        php_error_docref(NULL, E_WARNING,
                "PHP needs to be recompiled with a larger value of FD_SETSIZE.\n"
                "If this binary is from an official www.php.net package, file a bug report\n"
                "at http://bugs.php.net, including the following information:\n"
                "FD_SETSIZE=%d, but you are using %d.\n"
                " --enable-fd-setsize=%d is recommended, but you may want to set it\n"
                "to match to maximum number of sockets each script will work with at\n"
                "one time, in order to avoid seeing this error again at a later date.",
                FD_SETSIZE, max_fd, (max_fd + 128) & ~127);
#else
        php_error_docref(NULL, E_WARNING,
                "You MUST recompile PHP with a larger value of FD_SETSIZE.\n"
                "It is set to %d, but you have descriptors numbered at least as high as %d.\n"
                " --enable-fd-setsize=%d is recommended, but you may want to set it\n"
                "to equal the maximum number of open files supported by your system,\n"
                "in order to avoid seeing this error again at a later date.",
                FD_SETSIZE, max_fd, (max_fd + 1024) & ~1023);
#endif
}

继续搜 _php_emit_fd_setsize_warning 这个函数,找到定义如下
vim main/php_network.h +220

 # define PHP_SAFE_MAX_FD(m, n)          do { if (m >= FD_SETSIZE) { _php_emit_fd_setsize_warning(m); m = FD_SETSIZE - 1; }} while(0)

再搜 PHP_SAFE_MAX_FD 这个函数,找到 stream_select 函数的实现,只保留 max_fd相关代码的如下
vim ext/standard/streamsfuncs.c +797

PHP_FUNCTION(stream_select)
{
        php_socket_t max_fd = 0;
        if (r_array != NULL) {
                set_count = stream_array_to_fd_set(r_array, &rfds, &max_fd);
                if (set_count > max_set_count)
                        max_set_count = set_count;
                sets += set_count;
        }
        if (w_array != NULL) {
                set_count = stream_array_to_fd_set(w_array, &wfds, &max_fd);
                if (set_count > max_set_count)
                        max_set_count = set_count;
                sets += set_count;
        }
        if (e_array != NULL) {
                set_count = stream_array_to_fd_set(e_array, &efds, &max_fd);
                if (set_count > max_set_count)
                        max_set_count = set_count;
                sets += set_count;
        }
        
        PHP_SAFE_MAX_FD(max_fd, max_set_count);        
}

其中调用了函数 stream_array_to_fd_set,该函数定义在
vim ext/standard/streamsfuncs.c +607
核心逻辑是循环遍历当前的socket,找到找到当前监听的socket中fd的最大值。

梳理整个链路,可以得出的结论是,在调用stream_select时,如果监听的socket中出现了超过FD_SETSIZE 的fd值,就会出现这个 WARNING信息。

FD_SETSIZE

这里提到 https://bugs.php.net/bug.php?id=37025 的一个解决办法是
修改 /usr/include/bits/typesizes.h 中 __FD_SETSIZE 的值,然后重新编译PHP

/* Number of descriptors that can fit in an `fd_set'.  */
#define __FD_SETSIZE            1024

由于每个进程的fd是隔离的,单个php-fpm进程连接rabbitmq的socket数超过1024实在很难想象,猜测的话,有两种可能,
1)代码存在bug,导致不断尝试建立到rabbitmq的连接,最终超过了1024个;
2)建立mq连接后,没有及时释放;

在amqplib中 https://github.com/php-amqplib/php-amqplib/issues/693
也提到 修改另一个参数 LimitNPROC

LimitNPROC=4096

–enable-fd-setsize 设置描述集的大小

  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2021-08-25 11:59:32  更:2021-08-25 12:00:11 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 5:56:53-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码