Hello again, i did a new setup of our Apache and mod_perl2 with your hint´s.. Configured again some startup.pl stuff. but no luck 8-)
Error is still the same in error.log from apache. [Thu Feb 14 14:33:58 2008] [error] [Thu Feb 14 14:33:58 2008] -e: Can't locate object method "request" via package "Apache" at /usr/lib/cgi-bin/test1.pl line 4.\n Code looks like this for test1.pl #!/usr/bin/perl my $r = Apache->request; $r->send_http_header('text/plain'); $r->print("mod_perl rules!\n"); Hmm. Is someone able to use this code under apache2 with compat enabled. Perhaps it is broken in some ways ? bye Roman -----Ursprüngliche Nachricht----- Von: André Warnier [mailto:[EMAIL PROTECTED] Gesendet: Mittwoch, 13. Februar 2008 23:01 An: modperl@perl.apache.org Cc: Petry Roman, IT Betreff: Re: MP1 -> MP2 migration Problems. Of course, what I forgot to mention below - and sorry if you know that already - is that whichever perl modules you pre-load in your main Apache server config via the startup.pl script, you do not need to "use" anymore in all your perl scripts or Apache/mod_perl handlers. (At the cost of having them (insibly) duplicated in all the children processes). But it may simplify your migration problems, and you can always tune this later. André André Warnier wrote: > > 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: [EMAIL PROTECTED] [mailto:[EMAIL PROTECTED] 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 <[EMAIL PROTECTED]> >> 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 >> > -- This message has been scanned for viruses and dangerous content by MailScanner, and is believed to be clean. -- This message has been scanned for viruses and dangerous content by MailScanner, and is believed to be clean.