这章节搜集了很多编译时会产生的错误情况。 1. 我用匿名cvs得到最新版的源代码包, 但没有配置脚本文件! 2. 我在配置 php 在 apache下工作时出了问题。 它说不能找到 httpd.h, 可是我看它就在那里! 3. 当我运行conifgure时,它说它不能找到include文件或 一些库: gd, gdbm, 或其它的一些包! 4. 我在编译文件 language-parser.tab.c时, 出错,提示: yytname undeclared. 5. 当我运行 make, 起初正常但 最终失败了,在连接最后的应用时,出错说找不到一些文件。 6. 在连接 php 时, 出一堆错说 undefined references。 7. 我不清楚怎样在 apache 1.3下编译php。 8. 我按照步骤一步一步安装了apache模块(unix下), 可是在浏览器里打开 php 脚本时它却问我是否要保存。 9. 系统说使用: –activate-module=src/modules/php4/libphp4.a, 可那文件根本不存在, 我只好改成 –activate-module=src/modules/php4/libmodphp4.a 好了,它不工作了! 该怎么办? 10. 我要把php编译成apache的静态模块,用: –activate-module=src/modules/php4/libphp4.a 可是系统说我的编译器不是 ansi 兼容的。 11. 我用 –with-apxs编译php时, 我总是得到一些奇怪的错误。 12. 在 make时, 我得到很多关于microtime错误, 还有许多 rusage_ stuff. 13. 我想升级php,我在哪可以看到我现在运行的php 的当初配置安装时所使用的./configure 一行的内容? 14. 编译带gd库的php时,它不是给一些奇怪的错, 就是执行时产生 segfaults 段错误.

1. 我用匿名cvs得到最新版的源代码包, 但没有配置脚本文件!

你必须安装 gnu autoconf 包,这样可以从 configure.in生成配置脚本文件. 只要运行在cvs服务器得到源代码的顶级目录下的 ./buildconf。 (注意, 除非你运行configure –enable-maintainer-mode 选项, 配置脚本是不会重新生成, 即使configure.in 文件已更新, 所以当你发现 configure.in 改变了,你也要手工做一遍. 在config或config.status 运行后应该在你的makefile里能看到象@variable@这样的标号。)

2. 我在配置 php 在 apache下工作时出了问题。 它说不能找到 httpd.h, 可是我看它就在那里!

你要告诉 configure/setup 脚本 apache 的顶级目录的位置。 就是说你要标明 –with-apache=/path/to/apache , 而不是 –with-apache=/path/to/apache/src.

3. 当我运行conifgure时,它说它不能找到include文件或 一些库: gd, gdbm, 或其它的一些包!

你可以看看 configure 脚本,那些头文件或非标准库的位置,要送一些特殊的标志给c预处理器。例如: cppflags=-i/path/to/include ldflags=-l/path/to/library ./configure假如你的shell使用 csh-variant , 那么它将会是 (为什么?): env cppflags=-i/path/to/include ldflags=-l/path/to/library ./configure

4. 我在编译文件 language-parser.tab.c时, 出错,提示: yytname undeclared.

你需要更新你的 bison 版本. 你可以在 ftp://ftp.gnu.org/pub/gnu/bison/找到最新版本.

5. 当我运行 make, 起初正常但 最终失败了,在连接最后的应用时,出错说找不到一些文件。

一些老版本的 make 不能把 functions 目录下的编译的文件放到同一个目录下, 试着运行 cp *.o functions 然后再运行 make 看看是否会好些。 如果好了,你真的应该更新你的gnu make的版本了。

6. 在连接 php 时, 出一堆错说 undefined references。

看看文件里的连接行,确认所有的相关包都已经正确包含。通常这样是因为缺少’-ldl’,还有一些你想支持的数据库包。

如果你是在连接到 apache 1.2.x, 你记得要在在extra_libs 行增加一些额外的信息 并且重运行 apache’s configure 脚本吗? 参见发行包里的 install 文件。

很多人说他们一增加 ‘-ldl’ 马上得到了 libphp4.a 。

7. 我不清楚怎样在 apache 1.3下编译php。

事实上很简单,按下面的步骤:

取得 apache 1.3 源代码,在下面的位置 http://www.apache.org/dist/.

在某个目录下解压出来, 如 /usr/local/src/apache-1.3.

在php的发行包目录下,编译 php ,./configure –with-apache=/<path>/apache-1.3 ( 用户实际的apache-1.3目录位置替代 <path> .

打入: make 然后: make install 编译php,拷必须的文件到apache目录下。

改变到你的 /<path>/apache-1.3/src 目录,编辑 configuration文件. 把下面的行增加到文件里: addmodule modules/php4/libphp4.a.

打入: ./configure 然后: make.

这样你就有了一个 httpd 文件!

注意:你也可以使用新的apache ./configure 脚本. 见发行包里的 readme.configure 当然也要看看php发行包里的 install 文件。

8. 我按照步骤一步一步安装了apache模块(unix下), 可是在浏览器里打开 php 脚本时它却问我是否要保存。

这意味着你的php模块没有被加载。你可从下面三点来检查:

确认你运行的httpd是你刚刚编译了php的httpd. 可以运行: /path/to/binary/httpd -l

如果你没有看到 mod_php4.c 列出来,那么你运行了不正确的httpd. 最好重新安装它。

确认你在 apache .conf 文件里增加了正确的mime 类型.它应该是这样: addtype application/x-httpd-php3 .php3 ( php 3)

或 addtype application/x-httpd-php .php ( php 4)

也保证 addtype 这行没有包括在 <virtualhost> 或 <directory> 块里,它们会使它无效。

最后, apache 1.2 和 apache 1.3默认的配置文件的位置是不同的. 你应该检查你增加了addtype行的配置文件的位置 . 你可以在 httpd.conf 放一些明显的错误或改变,这样如果这文件被读的话,系统会通知你。

9. 系统说使用: –activate-module=src/modules/php4/libphp4.a, 可那文件根本不存在, 我只好改成 –activate-module=src/modules/php4/libmodphp4.a 好了,它不工作了! 该怎么办?

请注意 libphp4.a 事实并不存在. apache 进程会创建它!

10. 我要把php编译成apache的静态模块,用: –activate-module=src/modules/php4/libphp4.a 可是系统说我的编译器不是 ansi 兼容的。

这个错误消息是 apache 误导的,可以用更新版本来修正它。

11. 我用 –with-apxs编译php时, 我总是得到一些奇怪的错误。

出现这样的情况可以从三点来检查. 第一, 因为某种原因,apache 在编译apxs perl 脚本的时候, 它没有创建适当的标志变量, 找到你的apxs脚本 (试试命令 which apxs, 通常在 /usr/local/apache/bin/apxs or /usr/sbin/apxs. 打开它找到象下面这样的行: my $cfg_cflags_shlib  = ‘ ‘;          # substituted via makefile.tmplmy $cfg_ld_shlib      = ‘ ‘;          # substituted via makefile.tmplmy $cfg_ldflags_shlib = ‘ ‘;          # substituted via makefile.tmpl如果你看到的是这样,那么问题就出在这里. 因为值里包含的是空格或其它不正确的值, 如 ‘q()’. 把它样变成象下面的那样: my $cfg_cflags_shlib  = ‘-fpic -dshared_module’; # substituted via makefile.tmplmy $cfg_ld_shlib      = ‘gcc’;                   # substituted via makefile.tmplmy $cfg_ldflags_shlib = q(-shared);              # substituted via makefile.tmpl第二种可能仅仅出现在red hat 6.1 和 6.2上. apxs 脚本 red hat 版有错. 看这行: my $cfg_libexecdir    = ‘modules’;         # substituted via apaci install如果你看到了,就把它改成下面的行: my $cfg_libexecdir    = ‘/usr/lib/apache’; # substituted via apaci install第三, 你要是 重配置/重安装 apache, 必须在 ./configure 后,在 make之前,执行make clean

12. 在 make时, 我得到很多关于microtime错误, 还有许多 rusage_ stuff.

在安装过程中 make时,如果你看到下面的错: microtime.c: in function `php_if_getrusage’:microtime.c:94: storage size of `usg’ isn’t knownmicrotime.c:97: `rusage_self’ undeclared (first use in this function)microtime.c:97: (each undeclared identifier is reported only oncemicrotime.c:97: for each function it appears in.)microtime.c:103: `rusage_children’ undeclared (first use in this function)make[3]: *** [microtime.lo] error 1make[3]: leaving directory `/home/master/php-4.0.1/ext/standard’make[2]: *** [all-recursive] error 1make[2]: leaving directory `/home/master/php-4.0.1/ext/standard’make[1]: *** [all-recursive] error 1make[1]: leaving directory `/home/master/php-4.0.1/ext’make: *** [all-recursive] error 1

那是你的系统出错了. 你应该修复 /usr/include 文件.具体做法是安装和你的glibc匹配的glibc-devel 包. 这些错绝对和php无关,为了证明,你可以这样做: $ cat >test.c <<x#include <sys/resource.h>x$ gcc -e test.c >/dev/null如果出错,证明你的包含文件受损了.

13. 我想升级php,我在哪可以看到我现在运行的php 的当初配置安装时所使用的./configure 一行的内容.?

你可以看你安装php源目录下的 config.nice 文件. 如果不行还有另外一种方法.你只要简单运行 <?php phpinfo(); ?>脚本. 在输出页面的第一行,就是 ./configure 行, 是你当初用来配置php的那行.

14. 编译带gd库的php时,它不是给一些奇怪的错, 就是执行时产生 segfaults 段错误.

你必须确认你在编译 gd 库 和 php 时所使用同样的依赖库 (例如 libpng).