- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
经过数天的网络搜索、Stack Overflow、Google。到处,我无法理解在正常工作数小时后 PHP-fpm 发生了什么。
问题描述:
我有一个 Ubuntu 16.04 VPS,我在其中安装了 PHP-FPM 和 Nginx 以及一个小型 redis 服务器来存储 session 。我有 4 个网站在 PHP-fpm 下运行。所有网站都很好,只有一个网站有这个问题。
PHP-FPM 使用套接字与 Nginx 通信。
正常工作数小时后,当我运行 htop 命令时,PHP-FPM 进程突然无法工作并且状态为 D。这是 htop 命令输出的屏幕截图:
在网上查了一下,状态D表示进程正在等待资源。
我为 MySQL 服务器添加了更多内存,但没有任何反应。当我从工作台或任何其他应用程序执行命令时,MySQL 服务器没有问题。
可能是内存问题?
我为 VPS 添加了内存,现在它使用 6 GB 内存运行(大部分内存未使用)。 PHP-FPM 在运行数小时后继续保持状态 D。
可能与打开的文件描述符有关?
我将打开文件描述符的数量更改为 2097152,这是一个非常大的数字。我继续遇到同样的问题。
可能是套接字问题或 Linux 配置问题?
我增加了最多的 Linux 配置参数是这样的:
# Increase size of file handles and inode cache
fs.file-max = 2097152
# unix sockets accept by default 127 connections.
net.core.somaxconn = 4096
vm.swappiness = 0
vm.vfs_cache_pressure = 50
#Needed by redis
vm.overcommit_memory = 1
#
# 16MB per socket - which sounds like a lot, but will virtually never
# consume that much.
#
net.core.rmem_max = 16777216
net.core.wmem_max = 16777216
# Increase the number of outstanding syn requests allowed.
# c.f. The use of syncookies.
net.ipv4.tcp_max_syn_backlog = 8192
但我仍然遇到同样的问题。这是我在 nginx 日志中得到的:
2016/07/17 22:57:30 [alert] 1885#1885: *59394 open socket #156 left in connection 117
2016/07/17 22:57:30 [alert] 1885#1885: *59341 open socket #107 left in connection 118
2016/07/17 22:57:30 [alert] 1885#1885: *59385 open socket #148 left in connection 119
2016/07/17 22:57:30 [alert] 1885#1885: *59392 open socket #154 left in connection 121
我已经尝试了在网络上找到的大多数推荐解决方案,但都没有成功。
我已经在 PHP-fpm.conf 中更改了这些参数。
emergency_restart_threshold = 30
emergency_restart_interval = 180
process_control_timeout = 30
这是池的 PHP-fpm 配置:
pm = ondemand
pm.max_children = 30
pm.process_idle_timeout = 10s;
pm.max_requests = 500
这是我的 nginx 站点配置:
fastcgi_buffers 256 16k;
fastcgi_max_temp_file_size 0;
location ~ ^/index\.php(/|$) {
fastcgi_pass unix:/var/run/php5-fpm-mysite.com.sock;
fastcgi_split_path_info ^(.+\.php)(/.*)$;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
fastcgi_param DOCUMENT_ROOT $realpath_root;
internal;
}
Nginx 全局配置:
worker_processes 2;
worker_rlimit_nofile 100000;
pid /run/nginx.pid;
events {
worker_connections 1024;
multi_accept on;
}
最后一件事:两周前,我运行的是 Ubuntu 14.04,我已将服务器升级到 Ubuntu 16.04,但我遇到了很多问题。但是这个,我无法准确理解这个问题的根源。
我正在使用 Ocache 来缓存代码,我增加了所有参数以获得更多内存,并且网站工作正常并且缓存永远不会满。
我已经多次重启服务器以应用配置。
光盘:已满 50%。我有很多空间。
请注意,当 PHP-fpm 进程被阻止时,我重新启动了整个服务,几秒钟后,我遇到了同样的问题。我为 nginx 做了同样的事情,我遇到了同样的问题。 使网站正常工作的唯一方法是重新启动整个系统。
拜托,欢迎任何帮助!
最佳答案
经过几天寻找解决方案,问题与 Linux inode 无关,与内存无关,与套接字无关...
与应用程序代码有关。
我使用 Symfony2 框架,出于某些原因,我将参数“auto_generate_proxy_classes”更改为 true。我已将代码推向生产环境。
当 auto_generate_proxy_classes 设置为 true 时,Doctrine 将检查所有代理类并在每次请求时重新生成它们。所以当我收到很多请求时,php-fpm 进程将同时重新生成这些类。因此进程被阻塞,直到其他进程完成代码生成。
解决方案:
代替:
doctrine:
dbal:
....
orm:
auto_generate_proxy_classes: true.
放置默认的 Symfony2 配置:
doctrine:
dbal:
....
orm:
auto_generate_proxy_classes: "%kernel.debug%"
关于PHP Fpm 进程正在终止我的网站 : process is blocked with status D,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38426603/
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 5年前关闭。 Improve t
我是一名设计老师,试图帮助学生应对编程挑战,所以我编码是为了好玩,但我不是专家。 她需要找到 mode (最常见的值)在使用耦合到 Arduino 的传感器的数据构建的数据集中,然后根据结果激活一些功
我正在开发一个应用程序,该应用程序提供 CPU 使用率最高的 5 个应用程序名称。目前,我通过以下代码获得了排名前 5 的应用程序: var _ = require('lodash');
互联网上很少有例子涉及这个问题的所有三个问题——即 set-process-sentinel ; set-process-filter ;和 start-process . 我尝试了几种不同的方法来微
如 this post 中所述,在 C# 中有两种调用另一个进程的方法。 Process.Start("hello"); 和 Process p = new Process(); p.StartInf
我试图让我的桨从白色变为渐变(线性),并使球具有径向渐变。感谢您的帮助!您可以在 void drawPaddle 中找到桨的代码。 这是我的目标: 这是我的代码: //球 int ballX = 50
考虑:流程(a)根据我的文字: A process is first entered at the time of simulation, at which time it is executed u
我真的希望 Processing 有用于处理数组的 push 和 pop 方法,但由于它没有,我不得不试图找出删除数组中特定位置的对象的最佳方法。我相信这对很多人来说都是基本的,但我可以使用一些帮助,
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
以编程方式,我如何确定 Windows 10 中的 3 个类别 应用 后台进程 Windows 服务 就像任务管理器一样? 即我需要一些 C# 代码,我可以确定应用程序列表与后台进程列表。检查 Win
当我导入 node:process它工作正常。但是,当我尝试要求相同时,它会出错。 这工作正常: import process from 'node:process'; 但是当我尝试要求相同时,它会引
我正在上一门使用处理的类(class)。 我在理解 map() 函数时遇到问题。 根据它的文档( http://www.processing.org/reference/map_.html ): Re
我试图执行: composer.phar update 并收到: Fatal error: Allowed memory size of 94371840 bytes exhausted (tried
给定一堆二维图像,如何使用 Processing/Processing.js 产生体积渲染效果? 目前我的想法是使用 java(类似于 imageJ)进行体积渲染 -> 获取体积渲染图像的面作为单独的
这是代码示例 var startInfo = new ProcessStartInfo { Arguments = commandStr, FileName = @"C:\Window
当我在 Processing(草图 > 导入库 > 添加库)中添加库时,它安装在哪里? 最佳答案 它们安装在您的 中速写本位置 . 您可以通过转到"file">“首选项”来查看和更改您的速写本位置。草
无聊的好奇... 我正在查看当前进程的一些属性: using(Process p = Process.GetCurrentProcess()) { // Inspect properties
我正在尝试在同一页面上运行多个草图。 初始化脚本指定: /* * This code searches for all the * in your page and loads each scrip
Process.Kill 后是否需要使用 Process.WaitForExit? 如果调用进程在调用 Process.Kill 后立即退出怎么办? 这会导致 Process.Kill 失败吗? 编辑
我尝试使用处理从麦克风获取频率。我混合了文档中的两个示例,但“最高”并不是真正的赫兹(a 是 440 赫兹)。 你知道如何拥有比这更好的东西吗? import ddf.minim.*; import
我是一名优秀的程序员,十分优秀!