浅谈Tomcat乱码与端口占用的解决方案
Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP程序的首选。但是有些小伙伴在启动Tomcat时也会遇到各种各样的问题,比如Tomcat的startup.bat启动后出现乱码,端口占用,启动后闪退等问题,这里我们来一一进行解决
问题一:Tomcat的startup.bat启动后出现乱码
找到Tomcat文件下的conf目录,修改logging.properties文件中java.util.logging.ConsoleHandler.encoding对应的值为GBK
重启Tomcat,你看到的启动页面是这样的话,说明乱码问题已经解决
问题二:一闪而退之端口占用
启动Tomcat出现一闪而退的现象,其实还是可以看到Tomcat终端输出的日志,这时你需要迅速截图捕获异常,太南了。
最正确的方法是查看日志,找到Tomcat目录下的logs目录中catalina当天的日志,我这里找到的是C:\develop\Tomcat\apache-tomcat-8.5.47\logs\catalina.2019-10-17.log,在日志中可以看到类似这样的输出,Addressalreadyinuse:bind说明是端口占用了
17-Oct-201911:14:30.521严重[main]org.apache.catalina.core.StandardService.initInternalFailedtoinitializeconnector[Connector[HTTP/1.1-8080]] org.apache.catalina.LifecycleException:Protocolhandlerinitializationfailed atorg.apache.catalina.connector.Connector.initInternal(Connector.java:995) atorg.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:136) atorg.apache.catalina.core.StandardService.initInternal(StandardService.java:552) atorg.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:136) atorg.apache.catalina.core.StandardServer.initInternal(StandardServer.java:848) atorg.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:136) atorg.apache.catalina.startup.Catalina.load(Catalina.java:639) atorg.apache.catalina.startup.Catalina.load(Catalina.java:662) atsun.reflect.NativeMethodAccessorImpl.invoke0(NativeMethod) atsun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) atsun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) atjava.lang.reflect.Method.invoke(Method.java:498) atorg.apache.catalina.startup.Bootstrap.load(Bootstrap.java:309) atorg.apache.catalina.startup.Bootstrap.main(Bootstrap.java:492) Causedby:java.net.BindException:Addressalreadyinuse:bind atsun.nio.ch.Net.bind0(NativeMethod) atsun.nio.ch.Net.bind(Net.java:433) atsun.nio.ch.Net.bind(Net.java:425) atsun.nio.ch.ServerSocketChannelImpl.bind(ServerSocketChannelImpl.java:223) atsun.nio.ch.ServerSocketAdaptor.bind(ServerSocketAdaptor.java:74) atorg.apache.tomcat.util.net.NioEndpoint.bind(NioEndpoint.java:219) atorg.apache.tomcat.util.net.AbstractEndpoint.init(AbstractEndpoint.java:1118) atorg.apache.tomcat.util.net.AbstractJsseEndpoint.init(AbstractJsseEndpoint.java:224) atorg.apache.coyote.AbstractProtocol.init(AbstractProtocol.java:581) atorg.apache.coyote.http11.AbstractHttp11Protocol.init(AbstractHttp11Protocol.java:68) atorg.apache.catalina.connector.Connector.initInternal(Connector.java:993) ...13more
在Tomcat目录找到conf目录中的server.xml配置文件,在Connector标签中修改Tomcat启动端口
问题三:非端口问题的一闪而退
启动Tomcat直接一闪而退,在logs目录的日志里面找不到错误信息,这个时候很大可能是因为Tomcat与JDK版本不对应导致的,有可能你的Tomcat是Tomcat9版,而你的JDK是1.7版本的,Tomcat与JDK版本对应关系可以参考这篇文章Tomcat与JDK版本对应关系,Tomcat各版本特性
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。