PHP启动:无法加载动态库(NEW RELIC)

问题描述 投票:8回答:3

我正在使用Nginx和最新的PHP运行Ubuntu 12.04。故事是这样的:我试图按照ubuntu的说明安装新的遗留PHP代理:

wget -O - http://download.newrelic.com/548C16BF.gpg | sudo apt-key add -

sudo sh -c 'echo "deb http://apt.newrelic.com/debian/ newrelic non-free" 
> /etc/apt /sources.list.d/newrelic.list'

sudo apt-get update
sudo apt-get install newrelic-php5
sudo newrelic-install install

它不起作用。在所有事情之后,PHP代理根本无法启动。我甚至掀起了一个快速的phpinfo.php页面,看看是否列出了newrelic模块,但事实并非如此。然后我用Google搜索了“New relic .deb”并看到了这个页面:https://docs.newrelic.com/docs/server/server-monitor-installation-ubuntu-and-debian并按照说明进行操作。安装全部通过,但代理也无法启动。我喜欢保持我的服务器干净,所以我决定“好吧,因为它不起作用,直到新的遗物支持回到我身边,我可以从新的开始,我将删除已安装的新遗物”。所以我再次按照该链接上的说明进行操作。安装似乎正常。但是,如果我执行命令“PHP”,我会收到以下错误:

root@MYHOSTNAME:/home# php
PHP Warning:  PHP Startup: Unable to load dynamic library '/usr/lib/php5/20121212
/newrelic.so' - /usr/lib/php5/20121212/newrelic.so: cannot open shared object file:
No such file or directory in Unknown on line 0

我确保在我的/etc/php/fpm/php.ini文件中没有引用newrelic,并仔细检查以查看该文件夹中是否有任何内容。没有。

所以我的问题是:如何摆脱错误?如何让PHP停止尝试加载newrelic.so模块?在某些我可能会遗漏的地方是否有任何提及?

ubuntu nginx php newrelic
3个回答
18
投票

好的,我找到了答案。我无法用以下文章描述我对@mike的感激之情:Error In PHP5 ..Unable to load dynamic library。我跑了$ grep -Hrv ";" /etc/php5 | grep -i "extension=",它返回了一个大的文件列表,其中一个是/etc/php5/cli/conf.d/中的newrelic.ini,老实说,我甚至不知道是一个php目录。所以我运行sudo rm -rf /etc/php5/cli/conf.d/newrelic.ini并重新启动nginx和php5-fpm,问题解决了:)

谢谢@WayneWhitty的建议!我还要让newrelic知道他们应该在卸载脚本上修复它。


3
投票
  1. 确保检查PHP的/conf.d文件夹。如果那里有任何.ini文件,它们将被自动解析。如果您看到与newrelic相关的任何内容,请将其删除。在您的php信息文件中,如果要查看启动时自动加载了哪些.ini文件,请搜索Additional .ini files parsed
  2. 重启Nginx。

0
投票

在PHP7 CLI上,删除/etc/php/7.0/cli/conf.d/newrelic.ini

© www.soinside.com 2019 - 2024. All rights reserved.