Tomcat相关目录及配置文件总结

Posted 恒运兴

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Tomcat相关目录及配置文件总结相关的知识,希望对你有一定的参考价值。

Tomcat根目录介绍
    
【bin】目录主要是用来存放tomcat的命令,主要有两大类,一类是以.sh结尾的(linux命令),另一类是以.bat结尾的(windows命令)。
很多环境变量的设置都在此处,例如可以设置JDK路径、TOMCAT路径
startup 用来启动tomcat
shutdown 用来关闭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 的conf目录下各个配置文件

1. web.xml: 默认(欢迎)文件的设置

 在 tomcat4/conf/web.xml 中,<welcome-file-list>与IIS中的默认文件意思相同, 这也就是为什么我们只输入"主机地址 + 端口号" 就可以访问我们的项目了。
 

<welcome-file-list>
 
    <welcome-file>index.html</welcome-file>
 
   <welcome-file>index.htm</welcome-file>
 
     <welcome-file>index.jsp</welcome-file>
 
</welcome-file-list>

 

2. tomcat-users.xml:   

用户配置
      在进行具体Tomcat管理之前,先给tomcat添加一个用户,使这个用户有权限来进行管理。 
      打开conf目录下的tomcat-users.xml文件,在相应的位置添加下面一行: 

<user name="user" password="user" roles="standard,manager"/> 

  然后重启 tomcat,在浏览器中输入http://localhost:8080/manager/,会弹出对话框,输入上面的用户名和密码即可 。

  或者就是点击tomcat默认启动页右侧的三个按钮需要的访问权限。如下图所示: 

           

      

 

 

3. server.xml: 

下面讲述这个文件中的基本配置信息,更具体的配置信息请参考tomcat的文档:
    server: 
          1、port 指定一个端口,这个端口负责监听关闭tomcat的请求
          2、shutdown 指定向端口发送的命令字符串 


    service: 
          1、name 指定service的名字 


 Connector (表示客户端和service之间的连接):
          1、port 指定服务器端要创建的端口号,并在这个断口监听来自客户端的请求 
          2、minProcessors 服务器启动时创建的处理请求的线程数 
          3、maxProcessors 最大可以创建的处理请求的线程数 
          4、enableLookups 如果为true,则可以通过调用request.getRemoteHost()进行DNS查询来得到远程客户端的实际主机名,若为false则不进行DNS查询,而是返回其ip地址
          5、redirectPort 指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号 
          6、acceptCount 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理 
          7、connectionTimeout 指定超时的时间数(以毫秒为单位)

 

 

   Engine (表示指定service中的请求处理机,接收和处理来自Connector的请求):
          1、defaultHost 指定缺省的处理请求的主机名,它至少与其中的一个host元素的name属性值是一样的 

  Context (表示一个web应用程序):
          1、docBase 应用程序的路径或者是WAR文件存放的路径 
          2、path 表示此web应用程序的url的前缀,这样请求的url为  http://localhost:8080/path/**** 
          3、reloadable 这个属性非常重要,如果为true,则tomcat会自动检测应用程序的 /WEB-INF/lib  和 /WEB-INF/classes 目录的变化,自动装载新的应用程序,我们可以在不重起tomcat的情况下改变应用程序 


  host (表示一个虚拟主机):
          1、name 指定主机名 
          2、appBase 应用程序基本目录,即存放应用程序的目录 
          3、unpackWARs 如果为true,则tomcat会自动将WAR文件解压,否则不解压,直接从WAR文件中运行应用程序

 

Logger (表示日志,调试和错误信息):
          1、className 指定logger使用的类名,此类必须实现org.apache.catalina.Logger 接口 
          2、prefix 指定log文件的前缀 
          3、suffix 指定log文件的后缀 
          4、timestamp 如果为true,则log文件名中要加入时间,如例:localhost_log.2001-10-04.txt 


  Realm (表示存放用户名,密码及role的数据库):
          1、className 指定Realm使用的类名,此类必须实现org.apache.catalina.Realm接口 


   Valve (功能与Logger差不多,其prefix和suffix属性解释和Logger 中的一样):
          1、className 指定Valve使用的类名,如用org.apache.catalina.valves.AccessLogValve类可以记录应用程序的访问信息 


    directory(指定log文件存放的位置):
      1、pattern 有两个值,common方式记录远程主机名或ip地址,用户名,日期,第一行请求的字符串,HTTP响应代码,发送的字节数。combined方式比common方式记录的值更多


4. tomcat context.xml:

  1. 在tomcat 5.5之前:Context体现在/conf/server.xml中的Host里的<Context>元素,它由Context接口定义。每个<Context元素代表了运行在虚拟主机上的单个Web应用,例如: 

<Context path="/kaka" docBase="kaka" debug="0" reloadbale="true">

  1>path:即要建立的虚拟目录,,注意是/kaka,它指定访问Web应用的URL入口,如http://localhost:8080/kaka/****
  2>docBase:为实际目录在硬盘上的位置(应用程序的路径或者是WAR文件存放的路径)
  3>reloadable:如果这个属性设为true,Tomcat服务器在运行状态下会监视在WEB-INF/classes和Web-INF/lib目录CLASS文件的改变,如果监视到有class文件被更新,服务器自动重新加载Web应用,这样我们可以在不重起tomcat的情况下改变应用程序,也就是热部署。

  一个Host元素中嵌套任意多的Context元素。每个Context的路径必须是惟一的,而这个唯一性是由path属性定义确定的。另外,你必须定义一个path=“” 的context,这个Context称为该虚拟主机的缺省web应用,用来处理那些不能匹配任何Context的Context路径的请求。

  2. 在tomcat 5.5之后:不推荐在server.xml中进行配置,而是在/conf/context.xml中进行独立的配置。因为server.xml是不可动态重加载的资源,服务器一旦启动了以后,要修改这个文件,就得重启服务器才能重新加载。而context.xml文件则不然,tomcat服务器会定时去扫描这个文件。一旦发现文件被修改(时间戳改变了),就会自动重新加载这个文件,而不需要重启服务器。

<Context path="/kaka" docBase="kaka" debug="0" reloadbale="true" privileged="true">
<WatchedResource>WEB-INF/web.xml</WatchedResource>
<WatchedResource>WEB-INF/kaka.xml</WatchedResource>

  监控资源文件,如果web.xml || kaka.xml改变了,则自动重新加载改应用。

<Resource name="jdbc/testSiteds" 表示指定的jndi名称
  auth="Container" 表示认证方式,一般为Container
  type="javax.sql.DataSource"
  maxActive="100" 连接池支持的最大连接数
  maxIdle="30" 连接池中最多可空闲maxIdle个连接
  maxWait="10000" 连接池中连接用完时,新的请求等待时间,毫秒
  username="root" 表示数据库用户名
  password="root" 表示数据库用户的密码
  driverClassName="com.mysql.jdbc.Driver" 表示JDBC DRIVER
  url="jdbc:mysql://localhost:3306/testSite" /> 表示数据库URL地址

 


  附: context.xml的三个作用范围:
    1. tomcat server级别:
      在/conf/context.xml里配置
    2. Host级别:
      在/conf/Catalina/${hostName}里添加context.xml,继而进行配置
    3. web app 级别:
      在/conf/Catalina/${hostName}里添加${webAppName}.xml,继而进行配置

5. logging.properties

  该文件是在我们启动tomcat服务器的时候打印启动信息所用到的配置文件, 里面就是定义打印信息的规范

 

以上是关于Tomcat相关目录及配置文件总结的主要内容,如果未能解决你的问题,请参考以下文章

JavaWeb应用发布及相关配置

Tomcat部署及优化

Tomcat总结

Nginx 配置实例-配置负载均衡

Nginx 配置实例-配置负载均衡

怎样安装配置tomcat 8