編譯問(wèn)題
發(fā)表時(shí)間:2024-01-28 來(lái)源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]這章節(jié)搜集了很多編譯時(shí)會(huì)產(chǎn)生的錯(cuò)誤情況。 1. 我用匿名CVS得到最新版的源代碼包, 但沒(méi)有配置腳本文件! 2. 我在配置 PHP 在 Apache下工作時(shí)出了問(wèn)題。 它說(shuō)不能找到 httpd.h, 可是我看它就在那里! 3. 當(dāng)我運(yùn)行conifgure時(shí),它說(shuō)它不能找到include文件或 一些...
這章節(jié)搜集了很多編譯時(shí)會(huì)產(chǎn)生的錯(cuò)誤情況。 1. 我用匿名CVS得到最新版的源代碼包, 但沒(méi)有配置腳本文件! 2. 我在配置 PHP 在 Apache下工作時(shí)出了問(wèn)題。 它說(shuō)不能找到 httpd.h, 可是我看它就在那里! 3. 當(dāng)我運(yùn)行conifgure時(shí),它說(shuō)它不能找到include文件或 一些庫(kù): GD, gdbm, 或其它的一些包! 4. 我在編譯文件 language-parser.tab.c時(shí), 出錯(cuò),提示: yytname undeclared. 5. 當(dāng)我運(yùn)行 make, 起初正常但 最終失敗了,在連接最后的應(yīng)用時(shí),出錯(cuò)說(shuō)找不到一些文件。 6. 在連接 PHP 時(shí), 出一堆錯(cuò)說(shuō) undefined references。 7. 我不清楚怎樣在 Apache 1.3下編譯PHP。 8. 我按照步驟一步一步安裝了Apache模塊(Unix下), 可是在瀏覽器里打開(kāi) PHP 腳本時(shí)它卻問(wèn)我是否要保存。 9. 系統(tǒng)說(shuō)使用: --activate-module=src/modules/php4/libphp4.a, 可那文件根本不存在, 我只好改成 --activate-module=src/modules/php4/libmodphp4.a 好了,它不工作了! 該怎么辦? 10. 我要把PHP編譯成Apache的靜態(tài)模塊,用: --activate-module=src/modules/php4/libphp4.a 可是系統(tǒng)說(shuō)我的編譯器不是 ANSI 兼容的。 11. 我用 --with-apxs編譯PHP時(shí), 我總是得到一些奇怪的錯(cuò)誤。 12. 在 make時(shí), 我得到很多關(guān)于microtime錯(cuò)誤, 還有許多 RUSAGE_ stuff. 13. 我想升級(jí)PHP,我在哪可以看到我現(xiàn)在運(yùn)行的PHP 的當(dāng)初配置安裝時(shí)所使用的./configure 一行的內(nèi)容? 14. 編譯帶GD庫(kù)的PHP時(shí),它不是給一些奇怪的錯(cuò), 就是執(zhí)行時(shí)產(chǎn)生 segfaults 段錯(cuò)誤.
1. 我用匿名CVS得到最新版的源代碼包, 但沒(méi)有配置腳本文件!
你必須安裝 GNU autoconf 包,這樣可以從 configure.in生成配置腳本文件. 只要運(yùn)行在CVS服務(wù)器得到源代碼的頂級(jí)目錄下的 ./buildconf。 (注意, 除非你運(yùn)行configure --enable-maintainer-mode 選項(xiàng), 配置腳本是不會(huì)重新生成, 即使configure.in 文件已更新, 所以當(dāng)你發(fā)現(xiàn) configure.in 改變了,你也要手工做一遍. 在config或config.status 運(yùn)行后應(yīng)該在你的Makefile里能看到象@VARIABLE@這樣的標(biāo)號(hào)。)
2. 我在配置 PHP 在 Apache下工作時(shí)出了問(wèn)題。 它說(shuō)不能找到 httpd.h, 可是我看它就在那里!
你要告訴 configure/setup 腳本 Apache 的頂級(jí)目錄的位置。 就是說(shuō)你要標(biāo)明 --with-apache=/path/to/apache , 而不是 --with-apache=/path/to/apache/src.
3. 當(dāng)我運(yùn)行conifgure時(shí),它說(shuō)它不能找到include文件或 一些庫(kù): GD, gdbm, 或其它的一些包!
你可以看看 configure 腳本,那些頭文件或非標(biāo)準(zhǔn)庫(kù)的位置,要送一些特殊的標(biāo)志給C預(yù)處理器。例如: CPPFLAGS=-I/path/to/include LDFLAGS=-L/path/to/library ./configure假如你的shell使用 csh-variant , 那么它將會(huì)是 (為什么?): env CPPFLAGS=-I/path/to/include LDFLAGS=-L/path/to/library ./configure
4. 我在編譯文件 language-parser.tab.c時(shí), 出錯(cuò),提示: yytname undeclared.
你需要更新你的 Bison 版本. 你可以在 ftp://ftp.gnu.org/pub/gnu/bison/找到最新版本.
5. 當(dāng)我運(yùn)行 make, 起初正常但 最終失敗了,在連接最后的應(yīng)用時(shí),出錯(cuò)說(shuō)找不到一些文件。
一些老版本的 make 不能把 functions 目錄下的編譯的文件放到同一個(gè)目錄下, 試著運(yùn)行 cp *.o functions 然后再運(yùn)行 make 看看是否會(huì)好些。 如果好了,你真的應(yīng)該更新你的GNU Make的版本了。
6. 在連接 PHP 時(shí), 出一堆錯(cuò)說(shuō) undefined references。
看看文件里的連接行,確認(rèn)所有的相關(guān)包都已經(jīng)正確包含。通常這樣是因?yàn)槿鄙?-ldl',還有一些你想支持的數(shù)據(jù)庫(kù)包。
如果你是在連接到 Apache 1.2.x, 你記得要在在EXTRA_LIBS 行增加一些額外的信息 并且重運(yùn)行 Apache's Configure 腳本嗎? 參見(jiàn)發(fā)行包里的 INSTALL 文件。
很多人說(shuō)他們一增加 '-ldl' 馬上得到了 libphp4.a 。
7. 我不清楚怎樣在 Apache 1.3下編譯PHP。
事實(shí)上很簡(jiǎn)單,按下面的步驟:
取得 Apache 1.3 源代碼,在下面的位置 http://www.apache.org/dist/.
在某個(gè)目錄下解壓出來(lái), 如 /usr/local/src/apache-1.3.
在PHP的發(fā)行包目錄下,編譯 PHP ,./configure --with-apache=/<path>/apache-1.3 ( 用戶(hù)實(shí)際的apache-1.3目錄位置替代 <path> .
打入: make 然后: make install 編譯PHP,拷必須的文件到Apache目錄下。
改變到你的 /<path>/apache-1.3/src 目錄,編輯 Configuration文件. 把下面的行增加到文件里: AddModule modules/php4/libphp4.a.
打入: ./Configure 然后: make.
這樣你就有了一個(gè) httpd 文件!
注意:你也可以使用新的Apache ./configure 腳本. 見(jiàn)發(fā)行包里的 README.configure 當(dāng)然也要看看PHP發(fā)行包里的 INSTALL 文件。
8. 我按照步驟一步一步安裝了Apache模塊(Unix下), 可是在瀏覽器里打開(kāi) PHP 腳本時(shí)它卻問(wèn)我是否要保存。
這意味著你的PHP模塊沒(méi)有被加載。你可從下面三點(diǎn)來(lái)檢查:
確認(rèn)你運(yùn)行的Httpd是你剛剛編譯了PHP的Httpd. 可以運(yùn)行: /path/to/binary/httpd -l
如果你沒(méi)有看到 mod_php4.c 列出來(lái),那么你運(yùn)行了不正確的Httpd. 最好重新安裝它。
確認(rèn)你在 Apache .conf 文件里增加了正確的Mime 類(lèi)型.它應(yīng)該是這樣: AddType application/x-httpd-php3 .php3 ( PHP 3)
或 AddType application/x-httpd-php .php ( PHP 4)
也保證 AddType 這行沒(méi)有包括在 <Virtualhost> 或 <Directory> 塊里,它們會(huì)使它無(wú)效。
最后, Apache 1.2 和 Apache 1.3默認(rèn)的配置文件的位置是不同的. 你應(yīng)該檢查你增加了AddType行的配置文件的位置 . 你可以在 httpd.conf 放一些明顯的錯(cuò)誤或改變,這樣如果這文件被讀的話,系統(tǒng)會(huì)通知你。
9. 系統(tǒng)說(shuō)使用: --activate-module=src/modules/php4/libphp4.a, 可那文件根本不存在, 我只好改成 --activate-module=src/modules/php4/libmodphp4.a 好了,它不工作了! 該怎么辦?
請(qǐng)注意 libphp4.a 事實(shí)并不存在. apache 進(jìn)程會(huì)創(chuàng)建它!
10. 我要把PHP編譯成Apache的靜態(tài)模塊,用: --activate-module=src/modules/php4/libphp4.a 可是系統(tǒng)說(shuō)我的編譯器不是 ANSI 兼容的。
這個(gè)錯(cuò)誤消息是 Apache 誤導(dǎo)的,可以用更新版本來(lái)修正它。
11. 我用 --with-apxs編譯PHP時(shí), 我總是得到一些奇怪的錯(cuò)誤。
出現(xiàn)這樣的情況可以從三點(diǎn)來(lái)檢查. 第一, 因?yàn)槟撤N原因,Apache 在編譯apxs Perl 腳本的時(shí)候, 它沒(méi)有創(chuàng)建適當(dāng)?shù)臉?biāo)志變量, 找到你的apxs腳本 (試試命令 which apxs, 通常在 /usr/local/apache/bin/apxs or /usr/sbin/apxs. 打開(kāi)它找到象下面這樣的行: my $CFG_CFLAGS_SHLIB = ' '; # substituted via Makefile.tmplmy $CFG_LD_SHLIB = ' '; # substituted via Makefile.tmplmy $CFG_LDFLAGS_SHLIB = ' '; # substituted via Makefile.tmpl如果你看到的是這樣,那么問(wèn)題就出在這里. 因?yàn)橹道锇氖强崭窕蚱渌徽_的值, 如 '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第二種可能僅僅出現(xiàn)在Red Hat 6.1 和 6.2上. apxs 腳本 Red Hat 版有錯(cuò). 看這行: my $CFG_LIBEXECDIR = 'modules'; # substituted via APACI install如果你看到了,就把它改成下面的行: my $CFG_LIBEXECDIR = '/usr/lib/apache'; # substituted via APACI install第三, 你要是 重配置/重安裝 Apache, 必須在 ./configure 后,在 make之前,執(zhí)行make clean
12. 在 make時(shí), 我得到很多關(guān)于microtime錯(cuò)誤, 還有許多 RUSAGE_ stuff.
在安裝過(guò)程中 make時(shí),如果你看到下面的錯(cuò): 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
那是你的系統(tǒng)出錯(cuò)了. 你應(yīng)該修復(fù) /usr/include 文件.具體做法是安裝和你的glibc匹配的glibc-devel 包. 這些錯(cuò)絕對(duì)和PHP無(wú)關(guān),為了證明,你可以這樣做: $ cat >test.c <<X#include <sys/resource.h>X$ gcc -E test.c >/dev/null如果出錯(cuò),證明你的包含文件受損了.
13. 我想升級(jí)PHP,我在哪可以看到我現(xiàn)在運(yùn)行的PHP 的當(dāng)初配置安裝時(shí)所使用的./configure 一行的內(nèi)容.?
你可以看你安裝PHP源目錄下的 config.nice 文件. 如果不行還有另外一種方法.你只要簡(jiǎn)單運(yùn)行 <?php phpinfo(); ?>腳本. 在輸出頁(yè)面的第一行,就是 ./configure 行, 是你當(dāng)初用來(lái)配置PHP的那行.
14. 編譯帶GD庫(kù)的PHP時(shí),它不是給一些奇怪的錯(cuò), 就是執(zhí)行時(shí)產(chǎn)生 segfaults 段錯(cuò)誤.
你必須確認(rèn)你在編譯 GD 庫(kù) 和 PHP 時(shí)所使用同樣的依賴(lài)庫(kù) (例如 libpng).