yyxxzz 发表于 2012-11-15 17:22

记录 apache 转 nginx 后碰到的一次坑

本帖最后由 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 的运行环境还是有点不一样的,切换的时候 需要注意一些坑


linux_c_py_php 发表于 2012-11-15 20:15

是cgi和fcgi的区别, cgi是web server的子进程, fcgi是独立运行的进程, fpm是fcgi进程的父进程作为管理器存在的, 所以环境变量的来源是不同的, 注意各自父进程的启动时环境变量即可.

yyxxzz 发表于 2012-11-16 11:35

回复 2# linux_c_py_php

php 在apache 环境下 一般是作为 apache的模块运行的吧

   

linux_c_py_php 发表于 2012-11-16 12:26

模块难道就不能以子进程的形式执行吗?

有兴趣读读我的开源Http server吧, 里面有CGI模块的实现.

https://github.com/liangdong/Server/tree/Http_Server

yyxxzz 发表于 2012-11-16 11:35 static/image/common/back.gif
回复 2# linux_c_py_php

php 在apache 环境下 一般是作为 apache的模块运行的吧

yyxxzz 发表于 2012-11-16 16:49

回复 4# linux_c_py_php

我知道cgi的原理,我的意思是 apache 大部分是用模块运行的,并没有用子进程跑php
   

linux_c_py_php 发表于 2012-11-16 18:43

看样你不是搞C的, 模块是什么你能说出个究竟? 当然不能了.

yyxxzz 发表于 2012-11-16 16:49 static/image/common/back.gif
回复 4# linux_c_py_php

我知道cgi的原理,我的意思是 apache 大部分是用模块运行的,并没有用子进程 ...

yyxxzz 发表于 2012-11-16 19:04

回复 6# linux_c_py_php


你在自问自答吗?
你的 这句 “模块难道就不能以子进程的形式执行吗? ”
你倒是给我看看 libphp5.so 里面有没有 fork php 子进程来执行

看看 libphp5.so 的输入表吧,还子进程,你以为就你懂

linux_c_py_php 发表于 2012-11-16 20:31

难道php打算占着CPU让httpd阻塞?

$ nm libphp5.so| grep fork
               U fork@@GLIBC_2.2.5

你不懂还是我不懂?

yyxxzz 发表于 2012-11-16 19:04 static/image/common/back.gif
回复 6# linux_c_py_php


yyxxzz 发表于 2012-11-17 14:22

linux_c_py_php 发表于 2012-11-16 20:31 static/image/common/back.gif
难道php打算占着CPU让httpd阻塞?

$ nm libphp5.so| grep fork


apache prefork, phpmodule 模式下,你 这样配置试试,只有一个apache子进程,你看看php 是不是要阻塞

<IfModule mpm_prefork_module>
StartServers          1
   MinSpareServers       1
   MaxSpareServers      1
   MaxClients          1
   MaxRequestsPerChild0
</IfModule>

我让你看libphp5.so 的输入表,你没看到里面有那么多导出函数吗,那些函数不是要实现php 的功能吗?
还需要 fork 一个php 进程去执行 php?

看来你对apache php 运行模式还是不熟,
strace 一个apache 的子进程看看,到底有没有 fork 一个php 子进程去执行

linux_c_py_php 发表于 2012-11-18 11:23

汗, 一个只会配置apache的对一个会实现apache的人说配置, 好幼稚.
页: [1] 2
查看完整版本: 记录 apache 转 nginx 后碰到的一次坑