perl-modperl mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From André Warnier ...@ice-sa.com>
Subject Re: MP1 -> MP2 migration Problems.
Date Wed, 13 Feb 2008 21:49:43 GMT

Hi.

About your problem below...

I am not sure that this is going to help, nor even if it is really 
relevant to your specific problem.  Just trying to give you ideas, 
because it reminds me of something.
Below are two configurations, of two of our systems which have slightly 
different versions of mod_perl and the rest.
I went through the same kind of problems you're going through, a while 
ago when going from Apache 1.x to Apache 2.x, and then again more 
recently when there were some changes in the mod_perl naming of modules 
between mod_perl 1.9xx and mod_perl 2.0, and then some additional things 
happened during a Linux Debian upgrade from Sarge to Etch, which changed 
the location where some Apache2 stuff was installed.
And there is still some difference to this day in some Perl scripts or 
modules between these two systems, which greatly bothers me, but it 
basically works.

The main difference is in the two first "use" statements in our 
"startup.pl" script (which I assume you are familiar with, as a way to 
pre-load some perl stuff when the server starts).
I do not remember precisely which problems we had, but they were of the 
same "general gist" as yours, so maybe this helps.
Here it goes :

1) system "colin"  (Debian Sarge, older)
=================
version (uname -a) :
Linux colin 2.6.8-11-amd64-k8 #1 Sun Oct 2 21:26:54 UTC 2005 x86_64 
GNU/Linux
Apache2 version : see below
Perl version (perl -v) : 5.8.4
mod_perl version (per Apache log) :
[Wed Feb 13 22:24:59 2008] [notice] Apache/2.0.54 (Debian GNU/Linux) 
DAV/2 mod_jk/1.2.6 PHP/4.3.10-22 mod_perl/1.999.21 Perl/v5.8.4 
configured -- resuming normal operations

mod_perl "startup.pl" script :  (invoked via "PerlRequire" in httpd config)
------------------------------

#!/usr/bin/perl
# modperl2_startup.pl
# Apache2 / mod_perl 2 startup script

   use Apache2 ();
   use Apache::compat ();
   use lib "/usr/lib/apache2/perllib";   # that's a local perl lib directory
   use lib "/home/EFS/lib"; # that also
   use ModPerl::Util ();
   use Apache::RequestRec ();
   use Apache::RequestIO ();
   use Apache::RequestUtil ();
   use Apache::Filter ();
   use Apache::ServerUtil ();
   use Apache::Connection ();
   use Apache::Log ();
   use Apache::Const -compile => qw(:common :log REDIRECT);
   use APR::Const -compile => ':common';
   use APR::Table ();
   use ModPerl::Registry ();
   use CGI ();
   CGI->compile(':all');
   1;

lines in httpd.conf :
(or, rather, in /etc/apache2/mods-available/perl.conf) :
PerlRequire "/usr/lib/apache2/perllib/modperl2_startup.pl"
SetEnv PERL5LIB "/usr/lib/apache2/perllib"




2) system "arthur"  (Debian Etch, more recent)
   ==================
version (uname -a) :
Linux arthur 2.6.18-4-686 #1 SMP Wed May 9 23:03:12 UTC 2007 i686 GNU/Linux

Apache2 version : see below
Perl version (perl -v) : 5.8.8
mod_perl version (per Apache log) :
[Wed Feb 13 22:29:38 2008] [notice] Apache/2.2.3 (Debian) DAV/2 
mod_jk/1.2.18 PHP/4.4.4-8+etch4 mod_ssl/2.2.3 OpenSSL/0.9.8c 
mod_perl/2.0.2 Perl/v5.8.8 configured -- resuming normal operations

mod_perl "startup.pl" script :
------------------------------

   #!/usr/bin/perl
# modperl2_startup.pl
# Apache2 / mod_perl 2 startup script

   use Bundle::Apache2 ();
   use Apache2::compat ();
   use lib "/usr/local/lib/apache2/perllib";  # that's a local perl lib 
directory
   use lib "/home/EFS/lib"; # that also
   use ModPerl::Util ();
   use Apache2::RequestRec ();
   use Apache2::RequestIO ();
   use Apache2::RequestUtil ();
   use Apache2::Filter ();
   use Apache2::ServerUtil ();
   use Apache2::Connection ();
   use Apache2::Log ();
   use Apache2::Const -compile => qw(:common :log REDIRECT);
   use APR::Const -compile => ':common';
   use APR::Table ();
   use ModPerl::Registry ();
   use CGI ();
   CGI->compile(':all');
   1;

lines in httpd.conf :
(or, rather, in /etc/apache2/mods-available/perl.conf) :
PerlRequire "/usr/local/lib/apache2/perllib/modperl2_startup.pl"
SetEnv PERL5LIB "/usr/local/lib/apache2/perllib"




Petry Roman, IT wrote:
> Hello Perrin, thanks for this hint.. here comes the output..
> 
> Lodded modules in %INC:
> re.pm	
> APR/Const.pm	
> File/Spec/Functions.pm	
> Apache2/URI.pm	
> APR/Status.pm	
> warnings.pm	
> Apache2/Connection.pm	
> Apache2/XSLoader.pm	
> Apache2/Util.pm	
> Fcntl.pm	
> Symbol.pm	
> Exporter.pm	
> ModPerl/RegistryCooker.pm	
> Apache2/Response.pm	
> File/Spec.pm	
> Apache2/Const.pm	
> Apache2/ServerUtil.pm	
> APR/Date.pm	
> ModPerl/Global.pm	
> mod_perl.pm	
> warnings/register.pm	
> XSLoader.pm	
> APR/Bucket.pm	
> /etc/apache2/mod_perl-startup.pl	
> Apache2/SubRequest.pm	
> Apache2/Log.pm	
> ModPerl/Const.pm	
> Apache/Table.pm	
> Apache2/Filter.pm	
> APR/URI.pm	
> base.pm	
> APR/Util.pm	
> File/Basename.pm	
> Config.pm	
> Apache2/RequestRec.pm	
> ModPerl/Util.pm	
> APR/Pool.pm	
> mod_perl2.pm	
> Carp.pm	
> File/Spec/Unix.pm	
> Apache2/RequestUtil.pm	
> APR.pm	
> Apache.pm	
> strict.pm	
> vars.pm	
> CGI/Carp.pm	
> constant.pm	
> APR/XSLoader.pm	
> Apache2/compat.pm	
> Apache2/ServerRec.pm	
> Apache2/Access.pm	
> Apache/Constants.pm	
> APR/Brigade.pm	
> AutoLoader.pm	
> Apache2/Module.pm	
> lib.pm	
> ModPerl/Registry.pm	
> DynaLoader.pm	
> Apache2/RequestIO.pm	
> Apache/File.pm	
> APR/Table.pm	
> sum: 61 
> 
> Looks ok i think. Apache.pm is loaded.. So why can´t i get it to work.. damn thing 8-).
> bye
> roman
> -----Ursprüngliche Nachricht-----
> Von: pharkins@gmail.com [mailto:pharkins@gmail.com]Im Auftrag von Perrin
> Harkins
> Gesendet: Mittwoch, 13. Februar 2008 20:47
> An: Petry Roman, IT
> Cc: modperl@perl.apache.org
> Betreff: Re: MP1 -> MP2 migration Problems.
> 
> 
> On Feb 13, 2008 9:09 AM, Petry Roman, IT <Roman.Petry@dillinger.biz> wrote:
>> Can't locate object method "request" via package "Apache" at /usr/lib/cgi-bin/test1.pl
line 4.
> 
> If Apache2::compat is loaded, it should create that namespace.  Dump
> %INC from your script and see if Apache.pm is in it.
> 
> - Perrin
> 

Mime
View raw message