- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 nginx 和 php-fpm 的问题,我已经在这个表格中搜索过,但我没有找到解决方案。
服务器:16核10GB内存
WARNING: [pool inter] server reached pm.max_children setting (20), consider raising it
[i]
listen = /var/run/fastcgi/i.sock
listen.allowed_clients = 127.0.0.1
listen.group = i
user = i
group = inter
pm = dynamic
pm.max_children = 20
pm.max_requests = 1000
pm.start_servers = 15
pm.min_spare_servers = 15
pm.max_spare_servers = 15
;request_terminate_timeout = 300
php_admin_value[error_log] = /var/log/php-fpm/i-error.log
php_admin_flag[log_errors] = on
php_value[session.save_handler] = files
php_value[session.save_path] = /var/lib/php/ = /
php_admin_value[open_basedir] = /www/public_html/:/tmp:/usr/share/php:/var/lib/php
strong textphp_admin_value[disable_functions] = dl,exec,passthru,shell_exec,system,proc_open,popen,curl_exec,curl_multi_exec,parse_ini_file,show_source
我尝试了很多不同的设置,但我不知道是什么原因,我希望有人能提供帮助。
最好的问候
最佳答案
无法确定问题的根本原因,因为我们不知道您的服务器运行的代码类型。
发生的情况是 PHP 无法以足够快的速度处理请求以跟上 nginx。
增加子进程的数量无济于事,您有 16 个核心和 20 个进程。这意味着您的操作系统将被迫安排进程,增加进程数不会使任何事情变得更快——您甚至不知道您是否受 CPU 或 I/O 限制。
要正确解决这个问题,您需要确定为什么PHP 跟不上。
您可以通过将其添加到池中来启用 PHP-FPM
slow_log 功能:
slowlog = /var/log/php-fpm/slow.log
request_slowlog_timeout = 1s
这将记录每个花费 1 秒或更长时间的请求到文件 /var/log/php-fpm/slow.log
检查日志文件,追溯是你的哪部分代码导致 PHP 响应缓慢,并修复真正的问题
要在解决真正的问题之前让您的站点保持响应,您需要另一台服务器来进行 PHP 处理。由于您使用的是 nginx
并且 php-fpm
是您的后端,因此设置更多服务器来处理动态请求处理是非常简单的。随着您的站点的增长和需求的增长,您可以通过将 php-fpm
服务添加到处理池来轻松添加更多后端处理能力。
免责声明:我并不是说您应该,但很高兴知道您有哪些选择。
# Define servers in the cluster
upstream phpcluster {
server 10.0.0.1:9000;
server 10.0.0.2:9000;
}
location ~ \.php$ {
try_files $uri /index.php =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass phpcluster; # Pass to phpcluster upstream. Additional load balancing rules can be defined in upstream block
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
关于php - 警告 : [pool inter] seems busy (you may need to increase pm. start_servers,或 pm.min/max_spare_servers),产生 8 个 child ,,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41159547/
我正在使用 boost.pool,但我不知道何时使用 boost::pool<>::malloc和 boost::pool<>::ordered_malloc ? 所以, boost::pool<>:
我目前正在尝试从 anaconda 中的 spy 控制台运行并行代码。我相信问题可能出在我的计算机不允许 anaconda 控制 CPU 核心上,但我不知道如何解决这个问题。 另一个有趣的点是,当我运
在了解 Python 的 multiprocessing 包(对于 Python 3.4 )时,我注意到 multiprocessing.Pool 是在类 BaseContext 中定义的 上下文.p
我有这样的程序: from multiprocessing import Pool import time def f(x): # I make a heavy code here to take t
我有一个模块 A,它通过获取数据并将其发送到模块 B、C、D 等进行分析,然后将它们的结果结合在一起来执行基本的 map/reduce。 但是模块 B、C、D 等似乎不能自己创建多处理池,否则我得到
所以我有一个脚本可以连接到大约 700 个设备并执行一系列命令,然后退出。我开始使用 Multiprocessing.Pool 和 Pool.map 来减少脚本的运行时间,并允许我同时登录多个设备。
在下面的链接中有对 Pool 类的 map 方法的解释。 它似乎阻塞直到结果准备好。这意味着不需要执行 pool.close(); pool.join() 在运行 pool.map 之后,但是它在 t
context 是 class multiprocessing.pool.Pool 构造函数中的可选参数。 Documentation只说: context can be used to specif
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: What's the difference between sending -release or -dra
不确定这是否是正确的论坛。 libvirt 页面链接在这里。如果这需要张贴在不同的地方请告诉我。 virsh pool-define-as 和 create-as 有什么区别?阅读 virsh 的手册
谁能告诉我Spring Cloud Feign Client是否提供或支持Http连接池,如果可以,那么如何配置诸如池大小的设置?我似乎在官方文档中找不到此内容。谢谢你。 最佳答案 通过调查,我将尝试
我在尝试运行 Flask 应用程序时遇到了一些困难。我收到以下导入错误: File "/db/mysql_utils.py", line 2, in import mysql.conne
我有一个 Node 项目,在其中使用 pg-pool 库。我已在我的依赖项中包含以下内容: "@types/pg-pool": "0.0.3", "pg": "^7.3.0", "pg-format"
在 python 2 中,multiprocessing.dummy.Pool 和 multiprocessing.pool.ThreadPool 之间有什么区别吗?源代码似乎暗示它们是相同的。 最佳
这个问题在这里已经有了答案: Concurrent.futures vs Multiprocessing in Python 3 (6 个答案) 关闭 5 年前。 请给我解释一下这两个类有什么区别?
multiprocessing 的文档states以下关于Pool.join() : Wait for the worker processes to exit. One must call clos
我找到了一些资源,但我不确定我是否理解。 我找到的一些资源是: http://help.sap.com/saphelp_nw70/helpdata/en/fc/eb2ff3358411d1829f00
我的 Javafx 应用程序抛出许多非法状态异常,我尚未能够在源中跟踪触发器。 任何人都可以指导我导致此问题的原因以及我应该在哪里查找原因。我很难在这里展示一些代码,因为我不知道是什么原因造成的。 任
参见下面的示例和执行结果: #!/usr/bin/env python3.4 from multiprocessing import Pool import time import os def in
我目前有一个连接到我的主数据库的开放池,它运行良好。但是现在,我想为另一个数据库打开一个新池。我完全按照设置第一个池的方式设置了新池,显然我编辑了数据库名称等。加载 setupHikari() 方法时
我是一名优秀的程序员,十分优秀!