配置文件
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>
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>