zip版tomcat(6,7)不能注册成windows服务或者注册后不能启动的问题解决

在日常的开发中,经常要使用到tomcat,一般情况下,我们只需要下载zip版的tomcat,并在ide中进行配置即可。而不需要将tomcat注册成服务,但在部署中,如果需要将tomcat部署到客户机器上时,就会出现一定问题了。
    一般情况下,如果要部署成服务的形式,就需要下载专门的windows安装版(一个exe的安装文件),在windows下进行安装。而这种安装 版,有一个问题就是,它默认的服务名就是tomcat6或tomcat7,而不能手动的进行修改。如果需要安装多个tomcat,就不能使用安装版了。在 这种情况下,我们一般是下载zip版的tomcat,通过service.bat的方式来将tomcat注册成服务。
     一般情况下,注册成服务的tomcat并不能启动,问题有很多种。我就在实际过程中发现的问题,一一列举出来,以方便碰到此问题的同学一起解决这个问题。

  1. A service specific error occurred: 0. 
  2.  
  3. More help is available by typing NET HELPMSG 3547. 
A service specific error occurred: 0.

More help is available by typing NET HELPMSG 3547.

     第一个问题:如果注册服务都注册不成功,则首先要检查注册服务所使用的命令能否检测到所安装的java。这个检查只需要查看命令行是否出现以下字样即可:

  1. Installing the service 'Tomcat6' ... 
  2. Using CATALINA_HOME:    E:/javaServer/tomcat6utf8 
  3. Using CATALINA_BASE:    E:/javaServer/tomcat6utf8 
  4. Using JAVA_HOME:        C:/jdk1.6.0_24 
  5. Using JVM:              C:/jdk1.6.0_24/jre/bin/server/jvm.dll 
  6. The service 'Tomcat6' has been installed. 
Installing the service 'Tomcat6' ...
Using CATALINA_HOME:    E:/javaServer/tomcat6utf8
Using CATALINA_BASE:    E:/javaServer/tomcat6utf8
Using JAVA_HOME:        C:/jdk1.6.0_24
Using JVM:              C:/jdk1.6.0_24/jre/bin/server/jvm.dll
The service 'Tomcat6' has been installed.

    如果出现以下字样,则表示已经检测到了java。

     第二个问题:网上经常说的msvcr71.dll和msvcp71.dll。这两个dll文件只需要放到windows的path环境变量可以找到的地方即可,并不需要特别的放到某一个特殊的地方。
    查看这个文件是否能够被找到的一个很简单的方法,即是在命令行输入这两个文件,如:

E:/javaServer/tomcat6utf8/bin>msvcr71.dll

    如果windows找到了这个文件,则就会弹出一个如何打开文件的对话框,请求你如果打开这个文件。这就表示windows已经找到了这个文件。
    当然,如果把这两个文件都copy到tomcat的bin目录下,也是一种解决方法(没做过测试)

     第三个问题:java版本和tomcat版本问题。
    这里说的版本问题并不简单地是一个jre5和jre6的问题,一般来说,安装tomcat6需要jre5,安装tomcat7需要jre6,这都是常识的问题。
    特殊的问题就是:你的tomcat版本需要和jvm的版本相一致。
    我碰到这个问题,总是找不到解决问题的方法,最后发现,如果将安装版里的tomcat.exe文件copy至zip版的bin目录,并覆盖原tomcat.exe文件,服务就能够正常启动,但它自带的zip版的tomcat.exe死活不能启动,查看了两个exe的区别,除了大小不一样,其它的配置都一样。我注意到一个问题,就是官方对于安装版的tomcat, 说明它可以试用于win32系统,也可以试用于64位系统,这就是问题的关键。
    我机器上的java版本是64位的,而下载的zip版tomcat是32位的,在启动tomcat时,会在logs目录下的jakata-service.log文件中出现以下内容:

  1. <span style="color: rgb(0, 0, 0);">[2011-03-31 12:00:45] [174  javajni.c] [error] %1 is not a valid Win32 application. 
  2.  
  3. [2011-03-31 12:00:45] [994  prunsrv.c] [error] Failed creating java C:/jdk1.6.0_24/jre/bin/server/jvm.dll 
  4. [2011-03-31 12:00:45] [1269 prunsrv.c] [error] ServiceStart returned 1 
  5. </span> 
[2011-03-31 12:00:45] [174  javajni.c] [error] %1 is not a valid Win32 application.

[2011-03-31 12:00:45] [994  prunsrv.c] [error] Failed creating java C:/jdk1.6.0_24/jre/bin/server/jvm.dll
[2011-03-31 12:00:45] [1269 prunsrv.c] [error] ServiceStart returned 1

      表示不能启动jvm。当我通过修改服务的注册表,将其使用时使用的jvm换成32位的jvm时,服务就启动了。这就表示,zip版的tomcat需要根据jvm来下载不同的zip。在官方下载中,确实看到了zip版的tomcat有32位和64位之分,我下载64位的tomcat下 来,注册成服务之后,tomcat直接启动成功。看来确实是jvm适用系统版本和tomcat适用系统版本不一致的问题。
    当然,在开发过程中,我们都是使用startup.bat来启动tomcat,这里面就没有涉及到exe的问题,实际上就是调用java来启动tomcat,因此这个问题不会出现。其实32位tomcat和64tomcat的区别,就在于它提供的tomcat.exe的不同。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值