0

本番環境(AIX 5.3)のmodperlセットアップでXML::Parserを使用しているときに問題が発生しました。開発では正常に動作しますが、本番環境では次のエラーで失敗します。

    [Tue Apr 03 08:44:03 2012] [error] Can't load '/wload/es1p/app/perl/lib/site_perl/5.10.1/aix/auto/XML/Parser/Expat/Expat.so' for mo
ule XML::Parser::Expat: Could not load module /wload/es1p/app/perl/lib/site_perl/5.10.1/aix/auto/XML/Parser/Expat/Expat.so.\n\tDepe
dent module /wload/es1p/app/usr/local/apache2/lib/libexpat.a(libexpat.so.1) could not be loaded.\n\tMember libexpat.so.1 is not fou
d in archive \nCould not load module /wload/es1p/app/perl/lib/site_perl/5.10.1/aix/auto/XML/Parser/Expat/Expat.so.\n\tDependent mod
le /wload/es1p/app/perl/lib/site_perl/5.10.1/aix/auto/XML/Parser/Expat/Expat.so could not be loaded. at /wload/es1p/app/perl/lib/5.
0.1/aix/DynaLoader.pm line 200.\n at /wload/es1p/app/perl/lib/site_perl/5.10.1/aix/XML/Parser.pm line 18\nCompilation failed in req
ire at /wload/es1p/app/perl/lib/site_perl/5.10.1/aix/XML/Parser.pm line 18.\nBEGIN failed--compilation aborted at /wload/es1p/app/p
rl/lib/site_perl/5.10.1/aix/XML/Parser.pm line 22.\nCompilation failed in require at /wload/es1p/app/perl/lib/site_perl/5.10.1/XML/
Path/XMLParser.pm line 7.\nBEGIN failed--compilation aborted at /wload/es1p/app/perl/lib/site_perl/5.10.1/XML/XPath/XMLParser.pm li
e 7.\nCompilation failed in require at /wload/es1p/app/perl/lib/site_perl/5.10.1/XML/XPath.pm line 13.\nBEGIN failed--compilation a
orted at /wload/es1p/app/perl/lib/site_perl/5.10.1/XML/XPath.pm line 13.\nCompilation failed in require at /wload/es1p/app/perl/lib
site_perl/5.10.1/Net/SAML2/IdP.pm line 23.\nBEGIN failed--compilation aborted at /wload/es1p/app/perl/lib/site_perl/5.10.1/Net/SAML
/IdP.pm line 23.\nCompilation failed in require at /wload/es1p/app/perl/lib/site_perl/5.10.1/Net/SAML2.pm line 69.\nBEGIN failed--c
mpilation aborted at /wload/es1p/app/perl/lib/site_perl/5.10.1/Net/SAML2.pm line 69.\nCompilation failed in require at /wload/es1p/
pp/usr/local/apache2/perl-bin/sso.pl line 4.\nBEGIN failed--compilation aborted at /wload/es1p/app/usr/local/apache2/perl-bin/sso.pl

expat / expat-develライブラリは/opt/freeware/lib、パッケージ(devとliveで同じもの)を使用してインストールされ、両方とも以下からの同じ出力を示しますldd Expat.so

Expat.so needs:
     /usr/lib/libc.a(shr.o)
     /opt/freeware/lib/libexpat.a(libexpat.so.1)
     /unix
     /usr/lib/libcrypt.a(shr.o)

dotfilesとmod_env構成の両方でLIBPATHを設定しようとしましたが、うまくいきませんでした。誰かが正確な答えを知っているとは思っていませんが、何を試すことができるかについてのアイデアが不足しているので、いくつかの提案を試してみたいと思っています。

編集:XML :: Parserを使用した同じスクリプトが、ライブサーバー上の通常のcgi-binスクリプトとして完全に機能することも指摘しておく必要があります。

4

1 に答える 1

0

1 つの考え: 2 つの異なる XML::Parser が製品サーバーにインストールされている可能性があります。あなたの CGI は 1 つを選び、あなたのスクリプトは別のものを選びますか?

スクリプト (prod および dev) と作業中の CGI から @INC を出力し、結果を比較します。

よろしく、

于 2012-04-03T12:29:26.793 に答える