0

新しいサーバーで Pear Mailqueue を実行しようとすると、次のエラー メッセージが表示されます。

PHP Warning:  require_once(MDB2.php): failed to open stream: No such file or directory in /usr/share/php5/PEAR/Mail/Queue/Container/mdb2.php on line 57
PHP Fatal error:  require_once(): Failed opening required 'MDB2.php' (include_path='.:/usr/share/php5:/usr/share/php5/PEAR') in /usr/share/php5/PEAR/Mail/Queue/Container/mdb2.php on line 57

私が奇妙だと思うのは、コードに「MDB2.php」(大文字) というファイルが欠落しているように見えますが、エラーの原因となっているファイルは「mdb2.php」(小文字) と呼ばれていることです。これが何かを意味するかどうかはわかりません。

私が知る限り、すべてのパスは正しく、PHP で正しく設定されています。これまでに調査して試した診断手順は次のとおりです。

# pear config-get php_dir
/usr/share/php5/PEAR

# pear version
PEAR Version: 1.9.4
PHP Version: 5.4.20
Zend Engine Version: 2.4.0
Running on: Linux myserver 3.11.10-7-default #1 SMP Mon Feb 3 09:41:24 UTC 2014 (750023e) x86_64

# php --ini
Configuration File (php.ini) Path: /etc/php5/cli
Loaded Configuration File:         /etc/php5/cli/php.ini
Scan for additional .ini files in: /etc/php5/conf.d
Additional .ini files parsed:      /etc/php5/conf.d/ctype.ini,
/etc/php5/conf.d/curl.ini,
/etc/php5/conf.d/dom.ini,
/etc/php5/conf.d/gd.ini,
/etc/php5/conf.d/iconv.ini,
/etc/php5/conf.d/json.ini,
/etc/php5/conf.d/mbstring.ini,
/etc/php5/conf.d/mysql.ini,
/etc/php5/conf.d/mysqli.ini,
/etc/php5/conf.d/openssl.ini,
/etc/php5/conf.d/pdo.ini,
/etc/php5/conf.d/pdo_mysql.ini,
/etc/php5/conf.d/pdo_sqlite.ini,
/etc/php5/conf.d/soap.ini,
/etc/php5/conf.d/sqlite3.ini,
/etc/php5/conf.d/tokenizer.ini,
/etc/php5/conf.d/xmlreader.ini,
/etc/php5/conf.d/xmlwriter.ini,
/etc/php5/conf.d/zip.ini,
/etc/php5/conf.d/zlib.ini

# php -c /etc/php5/cli/php.ini -r 'echo get_include_path()."\n";'
.:/usr/share/php5:/usr/share/php5/PEAR

# ls /usr/share/php5/PEAR/Mail/Queue/Container -lsah
total 100K
 20K -rw-r--r-- 1 root root  18K Dec 10 15:30 --MDB2.php
4.0K drwxr-xr-x 2 root root 4.0K Dec 10 15:48 .
4.0K drwxr-xr-x 3 root root 4.0K May  3  2014 ..
 16K -rw-r--r-- 1 root root  15K May  3  2014 creole.php
 16K -rw-r--r-- 1 root root  16K May  3  2014 db.php
 20K -rw-r--r-- 1 root root  20K May  3  2014 mdb.php
 20K -rw-r--r-- 1 root root  18K Dec 10 15:48 mdb2.php

したがって、ファイルはそこにありますが、エラーメッセージを信頼できる場合、ファイルの名前は大文字であると予想されます。--MDB2.phpまた、ファイルが何であるかもわかりません。

--MDB2.phpファイルの名前を に変更しようとしましMDB2.phpたが、次のエラーが発生します。

PHP Fatal error:  Cannot redeclare class Mail_Queue_Container_mdb2 in /usr/share/php5/PEAR/Mail/Queue/Container/mdb2.php on line 71

それ以外の場合、Pear は正しくインストールされているように見え、端末pearコマンドに反応します...

これは、Pear や Mail Queue などのバグのあるバージョンですか?

- 編集 -

ファイル mdb2.php には、早い段階で次の行が含まれています。

require_once 'MDB2.php';

それで、別の場所に存在するはずのその名前の別のファイルがあるかもしれません...?

-- 編集 2 --

別の投稿がこの情報を参照しているのを見たので、これが役立つかもしれません:

# pear list
Installed packages, channel pear.php.net:
=========================================
Package            Version State
Archive_Tar        1.3.11  stable
Console_Getopt     1.3.1   stable
DB                 1.8.2   stable
HTTP_Request       1.4.4   stable
MDB2               2.5.0b5 beta
MDB2_Driver_mysql  1.4.1   stable
MDB2_Driver_mysqli 1.5.0b4 beta
Mail               1.2.0   stable
Mail_Mime          1.8.8   stable
Mail_Queue         1.2.7   stable
Net_SMTP           1.6.2   stable
Net_Socket         1.0.10  stable
Net_URL            1.0.15  stable
PEAR               1.9.4   stable
SOAP               0.12.0  beta
Structures_Graph   1.0.4   stable
XML_Util           1.2.1   stable
4

1 に答える 1

1

にファイルがあるはずMDB2.phpです/usr/share/php5/PEAR

ブラウザにエラーはありますか?次に、Apache の PHP はphp.iniCLI とは異なります。

set_include_path('.:/usr/share/php5/PEAR');コードで使用して、機能するかどうかを試してください。存在する場合は、( 経由でphpinfo();) Apache php.ini ファイルを見つけて、そこで変更します。

于 2015-02-20T14:15:35.983 に答える