TOMCAT笔记

配置文件

server.xml

<?xml version="1.0" encoding="UTF-8"?>
<Server>
  <Listener className="org.apache.catalina.startup.VersionLoggerListener"/>
  <Listener SSLEngine="on" className="org.apache.catalina.core.AprLifecycleListener"/>
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener"/>
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/>
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener"/>
  <Listener className="org.apache.catalina.core.JasperListener" /><!-- TOMCAT7需注释掉这一行-->
  <GlobalNamingResources>
    <Resource auth="Container" description="User database that can be updated and saved" 
      factory="org.apache.catalina.users.MemoryUserDatabaseFactory" name="UserDatabase" 
      pathname="conf/tomcat-users.xml" type="org.apache.catalina.UserDatabase"/>
  </GlobalNamingResources>
  <Service>
    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"  maxThreads="800" minSpareThreads="50"/>
<!-- 
      port:监听的端口号
      address:监听的IP地址,对于拥有多个IP地址的服务器,可以通过此配置设定监听的IP地址
      protocol:使用的协议。默认值是HTTP/1.1,修改为org.apache.coyote.http11.Http11NioProtocol启动nio协议。
      connectionTimeout:客户请求连接的超时时间
      acceptCount:接受的最大请求数,当排队中的请求数量超出此值时,将会拒绝后面的请求
      maxConnections:最大连接数
      minSpareThreads:最小空闲线程数
      maxThreads:最大线程数
      compression:  是否启动gzip压缩
-->
    <Connector acceptCount="1000" compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain,application/msexcel"   
     compression="on" compressionMinSize="2048" connectionTimeout="60000" disableUploadTimeout="true" enableLookups="false" 
     executor="tomcatThreadPool" maxHttpHeaderSize="8192" maxThreads="2000" port="80" protocol="org.apache.coyote.http11.Http11NioProtocol" redirectPort="8443"/>
    <!-- Define an AJP 1.3 Connector on port 8009,不使用ajp连接器建议禁用-->
    <!-- 若使用apache整合tomcat部署集群,多个tomcat部署在同一个服务器中,此处的ajp协议端口必须不一样,并且需要增加jvmRoute属性,该属性的值即为workers.properties中的tomcat的名称-->
    <Connector connectionTimeout="60000" keepAliveTimeout="60000" maxThreads="500" port="8010" protocol="AJP/1.3" redirectPort="8443" jvmRoute="tomcat1"/>
    <Engine defaultHost="localhost" jvmRoute="tomcat1" name="Catalina">
<!--   
      <Host name="www.test.com" appBase="/www/webapps" unpackWARS="true" autoDeploy="true">
          <Context path="" docBase="ROOT" reloadble="true"/>
          <Context path="/test" docBase="test" reloadble="true" />
          <Alias>test.com</Alias>
      </Host>
-->
      <Realm className="org.apache.catalina.realm.LockOutRealm">
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>
      </Realm>
      <Host name="localhost"  appBase="webapps" unpackWARs="true" autoDeploy="true">
      </Host>
    </Engine>
  </Service>
</Server>
server.xml

jvm优化

修改bin/catalina.bat文件设置参数(第93行)
set JAVA_OPTS=-Dfile.encoding=UTF-8 -server-Xms1024m -Xmx2048m -XX:NewSize=512m -XX:MaxNewSize=1024m -XX:PermSize=256m-XX:MaxPermSize=256m -XX:MaxTenuringThreshold=10 -XX:NewRatio=2-XX:+DisableExplicitGC

context.xml

为部署在此tomcat实例上的所有web应用程序提供的默认被指文件;每个webapp都可以使用独有的context.xml,通常放置于webapp目录的meta-inf子目录中;常用于定义会话管理器、Realm以及JDBC等;

web.xml

为部署于此tomcat实例上的所有web应用程序提供的默认部署描述符;通常用于为webapp提供基本的servlet定义和mime映射表等;

tomcat-users.xml

该文件包含了所有Tomcat服务器的注册用户,其中有role(角色)、user(用户)两种信息。

catalina.policy

当基于-security选项启动tomcat实例时会读取此配置文件;此文件是JAVA的安全策略配置文件,配置访问codebase或某些Java类的权限。

catalina.properties

Java属性定义文件,设置类加载器路径、安全包列表和一些调整性能的参数信息。

logging.properties

定义日志相关的配置信息,如日志級別、文件路径等。

自带的软件

server status:
状态查看
app部署
host manager:
虚拟主机管理

LNMT

动静分离

locati / {
  root /web/htdocs;
  index index.jsp index.html index.htm;
}
location ~* \.(jsp|do) {
  proxy_pass http://192.168.1.1:8080;
}
location ~* \.(jpg|exe|pdf|gif|png) {
  proxy_pass http://192.168.1.2:8080;
}
http{
  upstream tomcat {
    server 192.168.10.6:8080;
    server 192.169.10.7:8080;
  }  
  server {
    location ~* \.(jsp|do) {
      proxy_pass http://tomcat;
    }
  }
}

用户session的处理

1.ip hash。
2.sticky cookie。
3.session复制。
4.session服务器。

LAMT

mod_ proxy(http, https, ajp):
mod_ proxy. conf

ProxyVia on
ProxyRequests off
ProxyPreserveHost on
ProxyPass 1 ajp://192. 168.10.6: 8009/
ProxyPassReverse / ajp://192.168.10.6: 8009/
<Location />
      Order Allow , Deny
      Allow from all
</Location>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容