设为首页 收藏本站
查看: 313|回复: 0

[经验分享] 记录 Tomcat 控制台信息

[复制链接]

尚未签到

发表于 2017-1-21 11:57:32 | 显示全部楼层 |阅读模式
我们使用tomcat开发的时候,一般是在windows平台下.有时控制台中输出的调试和测试信息很多,
    由于屏幕的滚动,不能及时看清和分析输出的信息.那么,有没有简单的方法来获取这些信息呢?
    按照习惯,先在google上搜索了一下,没有发现有价值的信息,就只能自己想办法了.
    在linux下,tomcat的控制台输出被自动重定向输出到logs目录下的catalina.out文件中.分析一下
    文件catalina.sh发现如下的片断.
       "$_RUNJAVA" $JAVA_OPTS $CATALINA_OPTS \
      -Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" -classpath "$CLASSPATH" \
      -Dcatalina.base="$CATALINA_BASE" \
      -Dcatalina.home="$CATALINA_HOME" \
      -Djava.io.tmpdir="$CATALINA_TMPDIR" \
      org.apache.catalina.startup.Bootstrap "$@" start \
      >> "$CATALINA_BASE"/logs/catalina.out 2>&1 &
    原来在linux下执行的时候,在执行参数的最后加入了重定向设置.
    在windows下,同样也有命令管道的重定向机制,于是就在catalina.bat中找到了相应的执行行(179行)
  将
  %_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath "%CLASSPATH%" -Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS% %ACTION%
  改为
  %_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath "%CLASSPATH%" -Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS% %ACTION% >>"%CATALINA_BASE%"\logs\catalina.txt
  然后点击startup.bat启动Tomcat,在logs下虽然生成了catalina.txt,但始终是0k大小,没有任何的内容.  这是怎么回事呢?
   经过进一步分析发现,执行startup的时候,重新打开了一个windows窗口,这种情况下,有可能造成重定向的失败.这和linux下是不同的.单独执行一下catalina.bat发现如下的提示:
   Using CATALINA_BASE:   D:\jakarta-tomcat-5.0.25
   Using CATALINA_HOME:   D:\jakarta-tomcat-5.0.25
   Using CATALINA_TMPDIR: D:\jakarta-tomcat-5.0.25\temp
   Using JAVA_HOME:       C:\Borland\JBuilder2005\jdk1.4
   Usage:  catalina ( commands ... )
   commands:
     debug             Start Catalina in a debugger
     debug -security   Debug Catalina with a security manager
     jpda start        Start Catalina under JPDA debugger
     run               Start Catalina in the current window
     run -security     Start in the current window with security manager
     start             Start Catalina in a separate window
     start -security   Start in a separate window with security manager
     stop              Stop Catalina
     version           What version of tomcat are you running?
     于是修改catalina.bat第42行
     call "%EXECUTABLE%" start %CMD_LINE_ARGS%
     为
     call "%EXECUTABLE%" run %CMD_LINE_ARGS%
     然后在此启动tomcat,再次查看catalina.txt,预期的信息果然如约而至!


   其实更简单的更改方法是:直接修改catalina.bat的第42行为
   call "%EXECUTABLE%" run %CMD_LINE_ARGS% >> ..\logs\catalina.txt
   当不需要的时候直接把..\logs\catalina.txt去掉就可以了,改起来很方便快捷.

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-331592-1-1.html 上篇帖子: 屏蔽tomcat目录列表功能 下篇帖子: tomcat 不显示日志
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表