- 论坛徽章:
- 0
|
本帖最后由 yyxxzz 于 2012-11-15 17:23 编辑
apache 跑在一台机器上,由于HEAD 请求太多,apache 有点抗不住,导致 php 响应很慢
换成nginx, php-fpm 搞定,没想到影响到一个业务,这个业务是在php 里面调用mysql 执行一个sql 文件
类似
system("mysql -uxx -pyy -f <zz.sql")
原来在apache phpmodule 的环境下是正常运行,换成新环境,执行报错,
Query is Empty...还有其他信息
然后我把这个命令放在shell 运行也是正常的,后来想是不是什么权限问题导致的,后来看了下 mysql 也有执行权限,zz.sql 文件也有读取权限
是什么问题?后来终于想到 php-fpm 已经有单独的进程 运行了,不是被包装成模块的 运行了,
进程有自己的运行环境,有PATH环境
系统默认环境
echo $PATH
/usr/local/mysql/bin:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin
而php-fpm 的环境配置是
<value name="environment">
<value name="HOSTNAME">$HOSTNAME</value>
<value name="PATH">/usr/local/bin:/usr/bin:/bin</value>
<value name="TMP">/tmp</value>
<value name="TMPDIR">/tmp</value>
<value name="TEMP">/tmp</value>
<value name="OSTYPE">$OSTYPE</value>
<value name="MACHTYPE">$MACHTYPE</value>
<value name="MALLOC_CHECK_">2</value>
</value>
和系统有点不一样,正是这个问题
原来 有2个 mysql 可执行文件
shell 输入 mysql -uxx -p 默认是 先去 /usr/local/mysql/bin 下找mysql
而php-cgi 默认是去 /usr/bin 下面去找 mysql
这2个mysql 版本不一致,导致执行zz.sql 出现效果不一样的问题
最终修改 system("mysql -uxx -pyy -f <zz.sql") 为 system("/usr/local/mysql/bin/mysql -uxx -pyy -f <zz.sql")
ok,修复
php-fpm 和apache phpmodule 的运行环境还是有点不一样的,切换的时候 需要注意一些坑
|
|