Tomcat相关目录及配置文件总结
转自:https://www.cnblogs.com/dion-90/articles/8917222.html
Tomcat根目录介绍
【bin】目录主要是用来存放tomcat的命令,主要有两大类,一类是以.sh结尾的(linux命令),另一类是以.bat结尾的(windows命令)。很多环境变量的设置都在此处,例如可以设置JDK路径、TOMCAT路径startup 用来启动tomcatshutdown 用来关闭tomcat修改catalina可以设置tomcat的内存
【conf】目录主要是用来存放tomcat的一些配置文件。
server.xml可以设置端口号、设置域名或IP、默认加载的项目、请求编码
web.xml可以设置tomcat支持的文件类型
context.xml可以用来配置数据源之类的
tomcat-users.xml用来配置管理tomcat的用户与权限
在Catalina目录下可以设置默认加载的项目
【lib】目录主要用来存放tomcat运行需要加载的jar包。例如,像连接数据库的jdbc的包我们可以加入到lib目录中来。
【logs】目录用来存放tomcat在运行过程中产生的日志文件,非常重要的是在控制台输出的日志。(清空不会对tomcat运行带来影响)在windows环境中,控制台的输出日志在catalina.xxxx-xx-xx.log文件中在linux环境中,控制台的输出日志在catalina.out文件中
【temp】目录用户存放tomcat在运行过程中产生的临时文件。(清空不会对tomcat运行带来影响)
【webapps】目录用来存放应用程序当tomcat启动时会去加载webapps目录下的应用程序。可以以文件夹、war包、jar包的形式发布应用。当然,你也可以把应用程序放置在磁盘的任意位置,在配置文件中映射好就行。
【work】目录用来存放tomcat在运行时的编译后文件,例如JSP编译后的文件。清空work目录,然后重启tomcat,可以达到清除缓存的作用。、
Tomcat的配置文件server.xml
<?xml version='1.0' encoding='utf-8'?> <!-- 完整的HTTP请求过程 用户(这里指的是使用同一台电脑的用户)发出一个请求,如http://localhost:8080/hello/index.jsp。 Conector发现是http/1.1协议,而且还是8080端口,于是就把请求接收后交给符合条件的Engine Engine通过请求中的主机名localhost查找满足条件的虚拟主机(Host) 找到后就去此虚拟主机指定的appBase(指项目所存放的目录)中去找名称为hello的项目 找到后就去此hello项目中的配置文件web.xml中找满足条件的虚拟路径/index.jsp 查找方式为:遍历所有<servlet-mapping>元素,看谁的<url-pattern>的值和用户请求的/index.jsp匹配(匹配逻辑) 找到后就根据<servlet-mapping>元素的<servlet-name>的值找<servlet>元素,看谁的<servlet-name>的值和它是一样的 找到后就执行此<servlet>元素中 <servlet-class>的值所指定的本项目src目录下的servlet类,如com.itheima.bqt.Login 执行后将产生的结果返回给用户 --> <Server port="8005" shutdown="SHUTDOWN"> <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" /> <Listener className="org.apache.catalina.core.JasperListener" /> <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" /> <Listener className="org.apache.catalina.mbeans.ServerLifecycleListener" /> <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" /> <GlobalNamingResources> <Resource name="UserDatabase" auth="Container" type="org.apache.catalina.UserDatabase" description="User database that can be updated and saved" factory="org.apache.catalina.users.MemoryUserDatabaseFactory" pathname="conf/tomcat-users.xml" /> </GlobalNamingResources>
<Service name="Catalina"> <!-- 在<Server>中只能有一个<Service>元素,它表示服务 -->
<!-- 在<Service>中可以有N个<Connector>元素,它表示连接,不同的Connector针对不同的协议,我们只需关心处理HTTP协议的元素 -->
<!-- port表示端口号,默认值为8080,修改为80以后在访问项目时就不用再给出端口号了,因为80是HTTP默认端口 -->
<Connector port="80" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
<!-- 在<Service>中只能有一<Engine>元素,它是处理引擎,用户最终连接最终是由Connector导入的Engine处理的 -->
<Engine name="Catalina" defaultHost="localhost">
<Realm className="org.apache.catalina.realm.UserDatabaseRealm"
resourceName="UserDatabase"/>
<!-- 在<Engine>中可以有N个<Host>元素,每个<Host>元素表示一个虚拟主机,每个主机都有自己的主机名name和项目目录appBase -->
<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true"
xmlValidation="false" xmlNamespaceAware="false">
<!-- 在<Host>中可以有N个<Context>元素,其中path指定的是项目虚拟路径,可以随意给出,docBase指定你的项目的真实存放的路径。指定后,访问时就不再通过项目名访问资源,而是通过path的值访问 -->
<Context path="" docBase="D:\JAVA\tomcat6\我的主页"/><!--配置为此虚拟主机(即某个网站)的主页-->
</Host>
<!--定义了另一个虚拟主机及其此主机的相对路径,相当于可以将搜狐和新浪的网站在同一台服务器中运行-->
<Host name="localhost2" appBase="webapps2"
unpackWARs="true" autoDeploy="true"
xmlValidation="false" xmlNamespaceAware="false">
</Host>
</Engine>
</Service>
</Server>
web应用的配置文件web.xml
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> //每定义一个servlet,eclipse都会自动配置<servlet>和 <servlet-mapping>标签 <servlet> <servlet-name>Login</servlet-name> //随意起一个【名字】,不要有空格和中文 <servlet-class>com.itheima.bqt.Login</servlet-class> //此名字对应的类(即要调用的servlet) </servlet> <servlet-mapping> <servlet-name>Login</servlet-name> //和上面的那个 <servlet-name>完全一致 <url-pattern>/servlet/Login</url-pattern> //为此名称对应的servlet指定一个【虚拟路径】 //注意:不管怎么配置,访问的时候前面都必须加上web应用的名称,如http://localhost:8888【/Login】/servlet/Login //注意:配置时不要忘了要在前面加上【“/”】,另外如果在后面加了“/”,访问时此“/”也必须在后面加上才可以 //注意:配置时只有一种情况是不需要在前面加“/”的,那就是使用【*.扩展名】通配符,但访问时,此“/”也不能少 //另外一种统配符格式为:【/xxx/*】,当然【/*】也是可以的,此时,仅http://localhost:8888/Login便可访问 //注意:【*】不可以!,另外【*.扩展名】的匹配级别最低! //注意:【/*】和【/】(缺省servlet)效果不太一样,都不建议配置 //解疑:之所以不和<servlet>组合成一个标签,是为了实现一个<servlet>可以对应多个<servlet-mapping> </servlet-mapping> <welcome-file-list> <welcome-file>index.jsp</welcome-file> //会自动生成一个名为index.jsp的文件,并设置为 </welcome-file-list> </web-app>
默认的Servlet
关于/conf/web.xml中的DefaultServlet
首先所有的请求进入tomcat,都会流经servlet,如果没有匹配到任何应用指定的servlet,那么就会流到默认的DefaultServlet
DefaultServlet被定义在/conf/web.xml中,配置文件中被定义的东西会在Tomcat启动的时候被加载,对所有的webapp都有效。
DefaultServlet在Tomcat中主要是做目录列表(Directory Listing)用。
静态资源(JSP,HTML等)都走这个DefaultServlet~
<servlet> <servlet-name>default</servlet-name> <servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class> <init-param> <param-name>debug</param-name> <param-value>0</param-value> </init-param> <init-param> <param-name>listings</param-name> <param-value>false</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet>
其他
tomcat的配置文件server.xml不支持中文注释的解决办法:
1、问题原因:server.xml头指定了使用utf8来解释这个文档内容,但是当我使用编辑器编辑这个文档的时候,输入的中文却不是utf8编码(而是ANSI编码),这样自然会出错。
2、解决:解决起来也很容易,使用记事本打开xml文件,输入中文注释,然后选择另存为,在弹出的对话框中选择utf-8编码。或者使用editplus,ultraedit等编辑器打开xml文件,在相关的菜单中修改文件的编码为utf-8格式,然后保存,这样就可以正常使用中文注释了。
3、总结,xml头定义中的encoding与xml文件自身的编码不一致会导致文件解释异常。
利用telnet演示向服务器请求访问web资源步骤:
cmd
telnet localhost 8888 (指定端口号)
回车
ctrl+]
回车
GET / HTTP/1.1 (这里访问的是主页)
回车
Host:localhost
回车
回车