%1在Apache服务器上不是有效的Win32应用程序
问题描述:
我有在Windows 7 x64上运行的Apache 2.2 32位服务器。我需要使用perl,所以我已经安装了草莓5.12.3 32位并配置了Apache,所以我有2个位置: primary - cgi only和secondary - 使用mod_perl。我的问题是,我可以运行没有任何问题从次级位置的网页和脚本,而主要位置生成500错误和错误日志条目说:%1在Apache服务器上不是有效的Win32应用程序
[Wed Dec 12 09:13:10 2012] [error] [client 127.0.0.1] (OS 193)%1 is not a valid win32 application. : couldn't create child process: 720193: login.pl
在Windows事件日志我有错误的脚本7001在控制台中运行精细。你知道什么是错的吗?
这里是我的Apache的httpd.conf
ServerRoot "C:/Apache2_2"
PerlSetEnv NO_CACHE 1
PerlSetEnv DEBUG_SQL 1
Listen 80
LoadModule actions_module modules/mod_actions.so
LoadModule alias_module modules/mod_alias.so
LoadModule asis_module modules/mod_asis.so
LoadModule auth_basic_module modules/mod_auth_basic.so
LoadModule authn_default_module modules/mod_authn_default.so
LoadModule authn_file_module modules/mod_authn_file.so
LoadModule authz_default_module modules/mod_authz_default.so
LoadModule authz_groupfile_module modules/mod_authz_groupfile.so
LoadModule authz_host_module modules/mod_authz_host.so
LoadModule authz_user_module modules/mod_authz_user.so
LoadModule autoindex_module modules/mod_autoindex.so
LoadModule cgi_module modules/mod_cgi.so
LoadModule dir_module modules/mod_dir.so
LoadModule env_module modules/mod_env.so
LoadModule include_module modules/mod_include.so
LoadModule isapi_module modules/mod_isapi.so
LoadModule log_config_module modules/mod_log_config.so
LoadModule mime_module modules/mod_mime.so
LoadModule negotiation_module modules/mod_negotiation.so
LoadModule setenvif_module modules/mod_setenvif.so
LoadModule ssl_module modules/mod_ssl.so
LoadModule perl_module modules/mod_perl.so
LoadFile "C:/strawberry/perl/bin/perl512.dll"
PerlSwitches -wT -IC:/home/kks/srv/bin
<IfModule !mpm_netware_module>
<IfModule !mpm_winnt_module>
User daemon
Group daemon
</IfModule>
</IfModule>
ThreadsPerChild 20
ServerAdmin [email protected]
DocumentRoot "C:/Apache2_2/htdocs"
ErrorLog "|perl bin/pipedLogClient.pl -e"
LogLevel warn
SetEnv PERLDB_OPTS "RemotePort=localhost:9000"
SetEnv DBGP_IDEKEY "kks"
<IfModule log_config_module>
LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
LogFormat "%h %l %u %t \"%r\" %>s %b" common
<IfModule logio_module>
LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio
</IfModule>
CustomLog "|perl bin/pipedLogClient.pl -a" common
</IfModule>
<IfModule alias_module>
Alias /primary/static/ "C:/home/kks/srv/bin/static/"
ScriptAlias /primary/ "C:/home/kks/srv/bin/"
#=== primary ===#
<Location "/primary/">
AllowOverride None
Options FollowSymLinks
Order allow,deny
Allow from all
</Location>
<Location "/primary/static/">
SetHandler default-handler
AllowOverride None
Options None
Order allow,deny
Allow from all
</Location>
Alias /secondary/static/ "C:/home/kks/srv/bin/static/"
ScriptAlias /secondary/ "C:/home/kks/srv/bin/"
<Location "/secondary/">
SetHandler perl-script
PerlResponseHandler ModPerl::Registry
PerlOptions +ParseHeaders
PerlCleanupHandler owf_cleanup
Options FollowSymLinks
Options +ExecCGI
Order allow,deny
Allow from all
</Location>
<Location "/secondary/static/">
SetHandler default-handler
Options None
Order allow,deny
Allow from all
</Location>
</IfModule>
答
入住login.pl shebang行,并确保perl的有指向您已经安装了草莓
我的猜测路径:错误消息指出您正尝试通过调用一个奇怪的可执行文件来创建一个进程。但是,您没有名为'%1'的可执行文件。打开'login.pl',然后在'open','system','exec','qx()'中搜索该文件,反向查看是否有错误。你可能只是忘记用一个值或其他东西来替换一个占位符。与此无关,错误7001被描述[这里](http://support.microsoft.com/kb/278658/en-us),并指向网络问题。 – amon
不是这样 - 任何脚本都会发生同样的情况 - 事件最简单。 – karex
另一个有希望的链接:[启动服务的问题](https://social.technet.microsoft.com/wiki/contents/articles/1452.event-id-7001-service-start-operations.aspx)。 – amon