后端修行 - idea中Tomcat无法启动成功

兄弟篇

Tomcat刚启动,报出端口被占用

问题1:Tomcat刚启动也就一两秒的时间,报出端口被占用 java.rmi.server.ExportException: Port already in use: 1099; nested exception is: java.net.BindException: Address already in use: JVM_Bind

形式 - 1
在这里插入图片描述
形式 - 2
在这里插入图片描述

idea内正常解决方式

修改jmx port的端口地址(JMX的端口不能和http的端口重合)
在这里插入图片描述

Tomcat自身解决方式

1.找出占用1099端口的进程,进入windows命令,查看什么进程占用了1099端口
2.使用命令netstat -aon|findstr 1099 找出占用1099端口的进程
3.然后关闭占用该端口的进程taskkill -f -pid 3756
4.重新启动Tomcat
5.如有问题可以跳转这里查看端口被占用方面的知识

Tomcat启动一半,报出debugging错误

问题2:启动tomcat进行到一半之后自动停止,报出 Method breakpoints may dramatically show down debugging

在这里插入图片描述

解决方式:清除断点,重新启动Tomcat

在这里插入图片描述

Tomcat启动一半卡死

问题3:此场景出现在Tomcat的调优部分,自己设置了Tomcat的占用内存,如果内存不够时 - 就会导致Tomcat在启动中卡死

在这里插入图片描述

解决方式

1.找到catalina.bat,因为调优的时候在catalina.bat文件加入了jvm的启动参数
在这里插入图片描述
2. 查看内部是否有 set JAVA_OPTS=-server -Xms1024m -Xmx1024m 配置
在这里插入图片描述
3.注释或删除这段代码再次运行tomcat就正常了, rem 是注释

rem set JAVA_OPTS=-server -Xms1024m -Xmx1024m

Tomcat本身的问题扩展

1、java配置路径有问题,请配置好jdk路径,具体参考java路径的配置吧。

扫描二维码关注公众号,回复: 8514320 查看本文章

2、项目未添加tomcat驱动,

(一般提示The superclass “javax.servlet.http.HttpServlet” was not found on the Java Build Path属于这一类)

解决方法:保证已经装了tomcat的情况下,eclipse中选择对应项目右键build path ->Configure build path -> Java build path->选择Libraries ->点击右方Add Library… ->Server Runtime ->选择自己的tomcat服务器->Finish

3、项目中的web.xml中配置的servlet的名称写错,tomcat无法识别,

(一般控制台提示java.util.concurrent.ExecutionException属于这种问题)

解决方法:检查自己配置的servlet名称和路径是否正确。

4、端口被占用,一般由于上一次非正常关闭tomcat或eclipse导致,( Port 8080 … is already in use)

解决方法:
①修改端口号(当然不建议这么做) Tomcat根目录/conf/Server.xml中修改,这里就不提了吧…
②关闭被占用的端口进程→ 到dos窗口(计算机开始里的查找中输入cmd)→ 输入 netstat -ano|findstr 8080 (8080是被占用的端口号,哪个被占用输入哪个)→ 回车后可以看到有正在使用的进程 → 再输入 taskkill /pid 8080 /f (这里的8080是正在使用的进程信息中最后一个数字编号) → 回车后会显示已结束进程,然后重新启动tomcat即可

Tomcat catalina.bat脚本分析

首先省去catalina.bat开头诸多注解,这些注解主要是讲解各个变量是干什么的。需要的话,自己看下英文就可以了。这里就不翻译了。

rem Guess CATALINA_HOME if not defined  查看是否在tomcat目录下,与startup.bat里相同
set CURRENT_DIR=%cd% 
if not "%CATALINA_HOME%" == "" goto gotHome 
set CATALINA_HOME=%CURRENT_DIR% 
if exist "%CATALINA_HOME%\bin\catalina.bat" goto okHome 
cd .. 
set CATALINA_HOME=%cd% 
cd %CURRENT_DIR% 
:gotHome 
if exist "%CATALINA_HOME%\bin\catalina.bat" goto okHome 
echo The CATALINA_HOME environment variable is not defined correctly 
echo This environment variable is needed to run this program 
goto end 
:okHome 

rem Get standard environment variables 
if exist "%CATALINA_HOME%\bin\setenv.bat" call"%CATALINA_HOME%\bin\setenv.bat" 如果存在setenv.bat脚本,调用它,我的tomcat 没有这个脚本 

rem Get standard Java environment variables 
if exist "%CATALINA_HOME%\bin\setclasspath.bat" goto okSetclasspath 查看是否存在setclasspath.bat脚本,如果存在,转到okSetclasspath位置 
echo Cannot find %CATALINA_HOME%\bin\setclasspath.bat 否则输出下面两行,并退出 
echo This file is needed to run this program 
goto end 
:okSetclasspath    okSetclasspath位置 

set BASEDIR=%CATALINA_HOME%   设定BASEDIR变量与CATALINA_HOME变量值相同 
call "%CATALINA_HOME%\bin\setclasspath.bat" %1   调用setclasspath.bat脚本并加上参数 
if errorlevel 1 goto end      如果存在错误退出 

rem Add on extra jar files to CLASSPATH   设定JSSE_HOME变量,如果存在加入CLASSPATH,不存在跳过 

if "%JSSE_HOME%" == "" goto noJsse    检查是否存在JSSE_HOME变量 
set CLASSPATH=%CLASSPATH%;%JSSE_HOME%\lib\jcert.jar;%JSSE_HOME%\lib\jnet.jar;%JSSE_HOME%\lib\jsse.jar如果有加入到CLASSPATH变量后面 
:noJsse                                   
set CLASSPATH=%CLASSPATH%;%CATALINA_HOME%\bin\bootstrap.jar  将bootstrap.jar加入到CLASSPATH里 

if not "%CATALINA_BASE%" == "" goto gotBase  如果CATALINA_BASE变量不为空,跳过,转到gotBase位置 
set CATALINA_BASE=%CATALINA_HOME%  如果为空,将CATALINA_BASE设为CATALINA_HOME变量的值 
:gotBase 

if not "%CATALINA_TMPDIR%" == "" goto gotTmpdir  CATALINA_TMPDIR不为空,跳过,转到gotTmpdir位置 
set CATALINA_TMPDIR=%CATALINA_BASE%\temp   如果为空,将 CATALINA_TMPDIR设为%CATALINA_BASE%\temp变量的值(即tomcat\temp) 
:gotTmpdir 

if not exist "%CATALINA_HOME%\bin\tomcat-juli.jar" goto noJuli  如果不存在tomcat-juli.jar这个类,转到noJuli位置 
set JAVA_OPTS=%JAVA_OPTS% -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager- Djava.util.logging.config.file="%CATALINA_BASE%\conf\logging.properties"  如果存在,将变量加入到JAVA_OPTS里 
:noJuli 


set JAVA_OPTS=%JAVA_OPTS% -Xms128m -Xmx512m -Dfile .encoding=UTF8-Duser.timezone=GMT -Djava.security.auth.login.config=%CATALINA_HOME%/conf/jaas.config 设定JAVA_OPTS变量 

echo Using CATALINA_BASE:   %CATALINA_BASE%     输出CATALINA_BASE变量值 
echo Using CATALINA_HOME:   %CATALINA_HOME%     输出CATALINA_HOME变量值 
echo Using CATALINA_TMPDIR: %CATALINA_TMPDIR% 输出CATALINA_TMPDIR变量值 
if ""%1"" == ""debug"" gotouse_jdk        如果变量%1里存在debug ,转到use_jdk位置 
echo Using JRE_HOME:       %JRE_HOME%     输出JRE_HOME变量值 
goto java_dir_displayed      转到java_dir_displayed 
:use_jdk 
echo Using JAVA_HOME:      %JAVA_HOME%    输出JAVA_HOME变量值 
:java_dir_displayed 
                       下面几行设定相应变量 
set _EXECJAVA=%_RUNJAVA%        
set MAINCLASS=org.apache.catalina.startup.Bootstrap 
set ACTION=start 
set SECURITY_POLICY_FILE= 
set DEBUG_OPTS= 
set JPDA= 

if not ""%1"" == ""jpda"" goto noJpda 
set JPDA=jpda 
if not "%JPDA_TRANSPORT%" == "" goto gotJpdaTransport 
set JPDA_TRANSPORT=dt_shmem 
:gotJpdaTransport 
if not "%JPDA_ADDRESS%" == "" goto gotJpdaAddress 
set JPDA_ADDRESS=jdbconn 
:gotJpdaAddress 
if not "%JPDA_SUSPEND%" == "" goto gotJpdaSuspend 
set JPDA_SUSPEND=n 
:gotJpdaSuspend 
if not "%JPDA_OPTS%" == "" goto gotJpdaOpts 
set JPDA_OPTS=-Xdebug-Xrunjdwp:transport=%JPDA_TRANSPORT%,address=%JPDA_ADDRESS%,server=y,suspend=%JPDA_SUSPEND%
:gotJpdaOpts 
shift 
:noJpda 

if ""%1"" == ""debug"" goto doDebug   如果%1为debug,转到doDebug,运行debug模式 
if ""%1"" == ""run"" gotodoRun        如果%1为run,转到doRun,运行正常模式 
if ""%1"" == ""start"" gotodoStart    如果%1为start,转到doStart,启动tomcat 
if ""%1"" == ""stop"" gotodoStop      如果%1为stop,转到doStop,关闭tocmat 
if ""%1"" == ""version"" goto doVersion如果%1为version,转到doVersion,显示tomcat的版本号 

echo Usage:  catalina ( commands ... ) 如果%1没有上述内容,输出下面几行,并结束 
echo commands: 
echo  debug            Start Catalina in a debugger 
echo   debug -security   Debug Catalina with a securitymanager 
echo   jpda start        StartCatalina under JPDA debugger 
echo  run              Start Catalina in the current window 

echo   run -security     Start in the currentwindow with security manager 
echo  start            Start Catalina in a separate window 
echo   start -security   Start in a separate window withsecurity manager 
echo  stop             Stop Catalina 
echo  version           Whatversion of tomcat are you running? 
goto end 

:doDebug 
shift                   将%2里的值转到%1 
set _EXECJAVA=%_RUNJDB%  将变量 _EXECJAVA设为_RUNJDB变量的值 
set DEBUG_OPTS=-sourcepath"%CATALINA_HOME%\..\..\jakarta-tomcat-catalina\catalina\src\share"  
设定DEBUG_OPTS变量 

if not ""%1"" == ""-security"" gotoexecCmd    
如果%1不为-security,转到execCmd位置 

shift       将%2里的值转到%1 
echo Using Security Manager       输出该行 
set SECURITY_POLICY_FILE=%CATALINA_BASE%\conf\catalina.policy 
设定SECURITY_POLICY_FILE变量的值 

goto execCmd     转到execCmd位置 

:doRun 
shift        将%2里的值转到%1 
if not ""%1"" == ""-security"" gotoexecCmd   如果%1不为-security,转到execCmd位置 
shift        将%2里的值转到%1 
echo Using Security Manager   输出该行 
set SECURITY_POLICY_FILE=%CATALINA_BASE%\conf\catalina.policy 
设定SECURITY_POLICY_FILE变量的值 

goto execCmd  转到execCmd位置 

:doStart 
shift        将%2里的值转到%1 
if not "%OS%" == "Windows_NT" goto noTitle  如果OS变量不为Windows_NT,转到noTitle 
set _EXECJAVA=start "Tomcat"%_RUNJAVA%       设定_EXECJAVA变量的值 
goto gotTitle      转到gotTitle位置 
:noTitle 
set _EXECJAVA=start %_RUNJAVA%    设定_EXECJAVA 变量的值 
:gotTitle               
if not ""%1"" == ""-security"" gotoexecCmd   如果%1不为-security,转到execCmd位置 
shift                   将%2里的值转到%1 
echo Using Security Manager        输出该行 
set SECURITY_POLICY_FILE=%CATALINA_BASE%\conf\catalina.policy   
设定SECURITY_POLICY_FILE变量的值 

goto execCmd       转到execCmd位置 

:doStop 
shift                将%2里的值转到%1 
set ACTION=stop       将ACTION的变量设为stop 
set CATALINA_OPTS=    设CATALINA_OPTS为空 

goto execCmd          转到execCmd位置 

:doVersion            显示tomcat版本号 
%_EXECJAVA% -classpath "%CATALINA_HOME%\server\lib\catalina.jar"org.apache.catalina.util.ServerInfo   执行该命令 
gotoend             结束该程序 

:execCmd           
rem Get remaining unshifted command line arguments and save them in the 
以下几行将命令参数存入CMD_LINE_ARGS变量中 

set CMD_LINE_ARGS= 
:setArgs 
if ""%1""=="""" goto doneSetArgs 
set CMD_LINE_ARGS=%CMD_LINE_ARGS% %1 
shift 
goto setArgs 
:doneSetArgs 

rem Execute Java with the applicable properties 
if not "%JPDA%" == "" gotodoJpda        如果JPDA变量不为空,转到doJpda位置 
if not "%SECURITY_POLICY_FILE%" == "" goto doSecurity 
如果SECURITY_POLICY_FILE变量不为空,转到doSecurity位置 

如果都没有执行下面命令,并结束该程序 
%_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% 
goto end 
:doSecurity        执行下面命令,并结束该程序 
%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS%-Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath"%CLASSPATH%" -Djava.security.manager-Djava.security.policy=="%SECURITY_POLICY_FILE%"-Dcatalina.base="%CATALINA_BASE%"-Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%"%MAINCLASS% %CMD_LINE_ARGS% %ACTION% 
goto end 
:doJpda   
如果SECURITY_POLICY_FILE变量不为空,转到doSecurityJpda位置,为空执行下面命令,并结束该程序   

if not "%SECURITY_POLICY_FILE%" == "" goto doSecurityJpda 
%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %JPDA_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% 
goto end 
:doSecurityJpda  执行下面命令,并结束该程序 
%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %JPDA_OPTS% %DEBUG_OPTS%-Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath"%CLASSPATH%" -Djava.security.manager-Djava.security.policy=="%SECURITY_POLICY_FILE%"-Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%"-Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS%%ACTION% 
goto end 

:end 

MyEclipse+Tomcat发布项目所遇问题

在使用MyEclipse+Tomcat发布项目的时候通常会给如下提示信息:[org.apache.catalina.core.AprLifecycleListener]-[INFO]The Apache Tomcat Native library which allows optimal performance in productionenvironments was not found on the java.library.path: (…你的系统环境PATH路径…)

在停止时发现出现如下信息
[org.apache.catalina.core.AprLifecycleListener]-[INFO] Failed shutdown ofApache Portable Runtime

解决:Windows下的安装配置与使用

1、先去 http://tomcat.heanet.ie/native/ 下载编译好的tcnative-1.dll 文件,也可以下载tomcat-native.zip自己进行编译
2、修改一下 catalina.bat,加上
set CATALINA_OPTS="-Djava.library.path=…/…/APR/lib"
因为我把这个DLL放在与Tomcat目录同级的APR/lib目录下,所以采用了相对路径。或者把dll加到你的系统变量PATH里之类的,最简单的方法应当就是把tcnative-1.dll文件放在Tomcat的bin目录下:)

这样设置后,启动可以看到信息如下:
[org.apache.coyote.http11.Http11AprProtocol]-[INFO] Initializing CoyoteHTTP/1.1 on http-9091
在停止时发现出现如下信息
[org.apache.coyote.http11.Http11AprProtocol]-[INFO] Pausing Coyote HTTP/1.1 onhttp-9091

[org.apache.coyote.http11.Http11AprProtocol]-[INFO] Stopping Coyote HTTP/1.1 onhttp-9091

这样就配置成功了

发布了247 篇原创文章 · 获赞 97 · 访问量 24万+

猜你喜欢

转载自blog.csdn.net/qq_20451879/article/details/98611597