Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP程序的首选。
Tomcat和Nginx、Apache(httpd)、lighttpd等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Servlet和JSP容器,独立的Servlet容器是Tomcat的默认模式。
不过,Tomcat处理静态HTML的能力不如Nginx/Apache服务器。
--------------------------------------------------------------------
作者:rightlzc 来源:CSDN
原文:https://blog.csdn.net/rightlzc/article/details/82720553
Tomcat 当然是需要JDK的了,直接用了我之前的笔记中JDK的部分
#-----------------------首先需要安装好Java------------------------------ rpm -qa | grep java #先查看自带java 如果有就卸载 rpm -e --nodeps java-1.4.2-gcj-compat-1.4.2.0-40jpp.115 #卸载 rpm -e --nodeps java-1.6.0-openjdk-1.6.0.0-1.7.b09.el5 #卸载 #或者yum -y remove 卸载 yum -y remove java-1.4.2-gcj-compat # # 使用挂载方式或sftp上传java到主机,或者winscp工具 # secureCRT中alt+p可开启sftp. 或者安装lrzsz yum -y install lrzsz #安装后,rz上传,sz下载 # 如果是tar包, 就tar zxvf jdk-8u161-linux-x64.tar.gz cd /usr/local/src/jdk1.8.0_161 # 修改用户下面的 .bash_profile文件,也可以用root用户修改/etc/profile文件 vim /etc/profile ... export JAVA_HOME=/usr/local/src/jdk1.8.0_161 export PATH=$PATH:$JAVA_HOME/bin :wq source /etc/profile #重新加载这个配置文件 which java java -version
# 如果要查找是否有过tomcat find / -name tomcat
安装Tomcat:
#-------------------------- tomcat ------------------------------------- # 下载 wget https://mirrors.cnnic.cn/apache/tomcat/tomcat-8/v8.0.53/bin/apache-tomcat-8.0.53.tar.gz tar zxvf apache-tomcat-8.0.53.tar.gz mv apache-tomcat-8.0.53 tomcat8053 cd tomcat8053/bin ./startup.sh # 启动 ./shutdown.sh # 停止 ./catalina.sh version # 查看版本
开启 web 管理界面,不是必须的。通常仅用于开发测试。
# 修改 conf/tomcat-users.xml 文件,可以使用web进入manager-gui 管理界面 <role rolename="manager"/> <role rolename="manager-gui"/> <role rolename="admin"/> <role rolename="admin-gui"/> <user username="admin" password="123456" roles="admin-gui,admin,manager-gui,manager"/>
-------------------------------- server.xml组件类别
顶级组件 :位于整个配置的顶层,如server。
容器类组件 :可以包含其它组件的组件,如service、engine、host、context。
连接器组件 :连接用户请求至tomcat,如connector。
被嵌套类组件:位于一个容器当中,不能包含其他组件,如Valve、logger。
-------------------------------- server.xml组件详解
engine :核心容器组件,catalina引擎,负责通过connector接收用户请求,并处理请求,将请求转至对应的虚拟主机host。
host :类似于httpd中的虚拟主机,一般而言支持基于FQDN的虚拟主机。
context :定义一个应用程序,是一个最内层的容器类组件(不能再嵌套)。配置context的主要目的指定对应对的webapp的根目录,类似于httpd的alias,其还能为webapp指定额外的属性,如部署方式等。
connector:接收用户请求,类似于httpd的listen配置监听端口的。
service(服务):将connector关联至engine,因此一个service内部可以有多个connector,但只能有一个引擎engine。service内部有两个connector,一个engine。因此,一般情况下一个server内部只有一个service,一个service内部只有一个engine,但一个service内部可以有多个connector。
server :表示一个运行于JVM中的tomcat实例。
Valve :阀门,拦截请求并在将其转至对应的webapp前进行某种处理操作,可以用于任何容器中,比如记录日志(access log valve)、基于IP做访问控制(remote address filter valve)。
logger :日志记录器,用于记录组件内部的状态信息,可以用于除context外的任何容器中。
realm :可以用于任意容器类的组件中,关联一个用户认证库,实现认证和授权。可以关联的认证库有两种:UserDatabaseRealm、MemoryRealm和JDBCRealm。
UserDatabaseRealm:使用JNDI自定义的用户认证库。
MemoryRealm:认证信息定义在tomcat-users.xml中。
JDBCRealm :认证信息定义在数据库中,并通过JDBC连接至数据库中查找认证用户。
---------------------------------------------------------------------
作者:rightlzc 来源:CSDN
原文:https://blog.csdn.net/rightlzc/article/details/82720553
#-------------------------- 启用 tomcat 的 APR 模式 -------------------------------------
# Tomcat可以使用APR来提供超强的可伸缩性和性能,更好地集成本地服务器技术。
# APR(Apache Portable Runtime)
# 是一个高可移植库,它是Apache HTTP Server2.x的核心。
# APR有很多用途,包括访问高级IO功能(例如sendfile,epoll和OpenSSL),
# OS级别功能(随机数生成,系统状态等等),本地进程管理(共享内存,NT管道和UNIXsockets)
# 这些功能可以使Tomcat作为一个通常的前台WEB服务器,能更好地和其它本地web技术集成,
# 总体上让Java更有效率作为一个高性能web服务器平台而不是简单作为后台容器。
#---------------------------------------------------------------------------
# 先下载以下的三个组件: http://apr.apache.org/download.cgi # 依次安装: cd /opt/tomcat8053/apr-1.6.3 ./configure --prefix=/usr/local/apr make && make install cd /opt/tomcat8053/apr-iconv-1.2.2 ./configure --prefix=/usr/local/apr-iconv --with-apr=/usr/local/apr make && make install cd /opt/tomcat8053/apr-util-1.6.1 ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr --with-apr-iconv=/usr/local/apr-iconv/bin/apriconv make && make install cd /opt/tomcat8053/bin/ tar zxvf tomcat-native.tar.gz cd tomcat-native-1.2.17-src/native ./configure --with-apr=/usr/local/apr --with-java-home=/opt/java # 如果出现openssl版本错误,则需要更新 wget https://www.openssl.org/source/openssl-1.0.2-latest.tar.gz tar zxf openssl-1.0.2-latest.tar.gz cd openssl-1.0.2p ./config --prefix=/usr/local/openssl -fPIC # 必须带这些参数 make make install mv /usr/bin/openssl ~ ln -s /usr/local/openssl/bin/openssl /usr/bin/openssl openssl version # 查看版本是否更新 # cd tomcat8053/bin/tomcat-native-1.2.17-src/native/ 重新执行下面的 ./configure --with-apr=/opt/apr --with-java-home=/usr/local/src/jdk1.8.0_161 --with-ssl=/usr/local/openssl make && make install # 将APR 添加到环境配置 设置程序共享库位置也就是 使用 export LD_LIBRARY_PATH vim /etc/profile # 或者 ~/.bash_profile export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/apr/lib # 重新加载 生效 source /etc/profile # 修改 server.xml 大约70行 的 protocol="HTTP/1.1" <Connector port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol" connectionTimeout="20000" redirectPort="8443" /> # 大约28行 改为 off <Listener ... SSLEngine="on" /> <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="off" /> # 重新启动 tomcat
更详细的优化方案是:
#------------------------ tomcat 优化 修改2个文件: ----------------------------------- java -Xmx4096m -version # 测试一下能否顺利执行 # catalina.sh 在顶部加入以下: 8G 或 16G 的方案设置一个即可。参数实在太多,解释可以网上搜到。 JAVA_HOME=/usr/local/src/jdk1.8.0_161 CATALINA_HOME=/opt/tomcat8053 CATALINA_OPTS="-server -Xms528m -Xmx528m -XX:PermSize=256m -XX:MaxPermSize=358m" CATALINA_PID=$CATALINA_HOME/catalina.pid # 8G mem JAVA_OPTS="-Dfile.encoding=UTF-8 -server -Xms6144m -Xmx6144m -XX:NewSize=1024m -XX:MaxNewSize=2048m -XX:PermSize=512m -XX:MaxPermSize=512m -XX:MaxTenuringThreshold=10 -XX:NewRatio=2 -XX:+DisableExplicitGC" # 16G mem JAVA_OPTS="-Dfile.encoding=UTF-8 -server -Xms13312m -Xmx13312m -XX:NewSize=3072m -XX:MaxNewSize=4096m -XX:PermSize=512m -XX:MaxPermSize=512m -XX:MaxTenuringThreshold=10 -XX:NewRatio=2 -XX:+DisableExplicitGC" # server.xml 修改大约57行和70行:启用线程池和使用APR <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="100" prestartminSpareThreads = "true" maxQueueSize = "100" /> ... <Connector executor="tomcatThreadPool" port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol" connectionTimeout="20000" maxConnections="10000" redirectPort="8443" enableLookups="false" acceptCount="100" maxPostSize="10485760" compression="on" disableUploadTimeout="true" compressionMinSize="2048" acceptorThreadCount="2" compressableMimeType="text/html,text/xml,text/plain,text/css,text/javascript,application/javascript" URIEncoding="utf-8" />
修改内存配置
这篇博客 http://my.oschina.net/xianggao/blog/83823 比较详细的介绍了Tomcat的一下内存。
JVM内存分配设置的参数有四个
-Xmx Java Heap最大值,默认值为物理内存的1/4;
-Xms Java Heap初始值,Server端JVM最好将-Xms和-Xmx设为相同值,开发测试机JVM可以保留默认值;
-Xmn Java Heap Young区大小,不熟悉最好保留默认值;
-Xss 每个线程的Stack大小,不熟悉最好保留默认值;
-XX:PermSize:设定内存的永久保存区域;
-XX:MaxPermSize:设定最大内存的永久保存区域;
-XX:PermSize:设定内存的永久保存区域;
-XX:NewSize:设置JVM堆的‘新生代’的默认大小;
-XX:MaxNewSize:设置JVM堆的‘新生代’的最大大小;
其实我们配置的基本上自由前面两个!贴出我的配置
要添加在tomcat 的bin 下catalina.sh 里,位置cygwin=false前 。
今天改了我的 catalina.sh的设置,运行了一会暂时没有发现问题。 这台机器是16G内存,但是还运行了rabbitMQ 所以不能占太多内存。
CATALINA_OPTS="-server -Xms6000M -Xmx6000M -Xss512k -XX:NewSize=1024M -XX:MaxNewSize=2048M -XX:PermSize=512M -XX:MaxPermSize=512M -XX:+AggressiveOpts -XX:+UseBiasedLocking -XX:MaxTenuringThreshold=10 -XX:NewRatio=2 -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8899"
tomcat这种东西真是不好用,设置参数都搞这么复杂。或许下面这个值得参考:
https://blog.csdn.net/qq_18279477/article/details/79171894
下面是 tomcat8的虚拟主机,一般常用的就是基于不同域名的或不同端口的虚拟主机。据说tomcat不支持基于IP的虚拟主机,原因是浪费IP资源。
#------------------------------ 不同域名的虚拟主机---------------------------- # server.xml中 复制<Host>...</Host>这一段,增加一段。 # 然后修改<Host name="你的域名" appBase="对应站点的目录" 其它可以不变 # 再增加一行:<Context path="" docBase="" debug="0" reloadable="false" crossContext="true"/> # <Value ... />可以不用修改 # 最后重启 tomcat 即可。
<Host name="node-666" appBase="/opt/tomcat8053/webapp2" unpackWARs="true" autoDeploy="true"> <Context path="" docBase="" debug="0" reloadable="false" crossContext="true"/> <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log" suffix=".txt" pattern="%h %l %u %t "%r" %s %b" /> </Host>
#------------------------------ 不同端口的虚拟主机---------------------------- # server.xml中 复制<Service>...</Service>这一段,增加一段。 # <Service name="不同的名称" # <Connector port="不同的端口" # <Engine name="不同的名称" # <Host name="localhost" appBase="不同的目录" # 以上4个参数修改一下即可,其它不用修改。 在 <Host ... > 下面再增加一行: # <Context path="" docBase="" debug="0" reloadable="false" crossContext="true"/> # 最后重启 tomcat 即可。
<Service name="Catalina2"> <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="100" prestartminSpareThreads = "true" maxQueueSize = "100" /> <Connector executor="tomcatThreadPool" port="8001" protocol="org.apache.coyote.http11.Http11AprProtocol" connectionTimeout="20000" maxConnections="10000" redirectPort="8443" enableLookups="false" acceptCount="100" maxPostSize="10485760" compression="on" disableUploadTimeout="true" compressionMinSize="2048" acceptorThreadCount="2" compressableMimeType="text/html,text/xml,text/plain,text/css,text/javascript,application/javascript" URIEncoding="utf-8" /> <Engine name="Catalina2" defaultHost="localhost"> <Realm className="org.apache.catalina.realm.LockOutRealm"> <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/> </Realm> <Host name="localhost" appBase="/opt/tomcat8053/webapp2" unpackWARs="true" autoDeploy="true"> <Context path="" docBase="" debug="0" reloadable="false" crossContext="true"/> <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log" suffix=".txt" pattern="%h %l %u %t "%r" %s %b" /> </Host> </Engine> </Service>
发现tomcat隔三差五天就死掉,只好 kill -9 PID, 然后 tomcat/bin/startup.sh
查看日志 tomcat/logs/catalina.2019-04-09.log 发现很多 Error
09-Apr-2019 00:02:05.298 SEVERE [http-apr-8080-Acceptor-1] org.apache.tomcat.util.net.AprEndpoint$Acceptor.run Socket accept failed
org.apache.tomcat.jni.Error: 24: Too many open files
然后开始找哪个 打开文件多:
netstat -nltp |grep java # 查进程 PID lsof -n|awk '{print $2}'|sort|uniq -c|sort -nr|more # 找到最多句柄数和PID lsof -p 2310 | wc -l # 查看打开数。 2310是tomcat的PID lsof |grep 2310 >> 2310.log # 内容太多,输出到文件
打开输出的文件,发现打开某个文件太多,很多行都是在请求同一个文件。于是让开发查找了程序bug, 可能因为打开文件后没有释放句柄。
更新代码后 tomcat 恢复正常
其实centos 的 ulimit -a 的 open files 我已经改到65535了。 vim /etc/security/limits.conf
root soft nofile 65535 root hard nofile 65535 * soft nofile 65535 * hard nofile 65535
检查一下 tomcat 进程的 limits
cat /proc/2310/limits