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.-gcj-compat-1.4.2.0-40jpp. #卸载
rpm -e --nodeps java-1.6.-openjdk-1.6.0.0-1.7.b09.el5 #卸载
#或者yum -y remove 卸载
yum -y remove java-1.4.-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..0_161 # 修改用户下面的 .bash_profile文件,也可以用root用户修改/etc/profile文件
vim /etc/profile
...
export JAVA_HOME=/usr/local/src/jdk1..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..tar.gz
mv apache-tomcat-8.0. 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.
./configure --prefix=/usr/local/apr
make && make install cd /opt/tomcat8053/apr-iconv-1.2.
./configure --prefix=/usr/local/apr-iconv --with-apr=/usr/local/apr
make && make install cd /opt/tomcat8053/apr-util-1.6.
./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.-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.-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.-src/native/ 重新执行下面的
./configure --with-apr=/opt/apr --with-java-home=/usr/local/src/jdk1..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="" protocol="org.apache.coyote.http11.Http11AprProtocol"
connectionTimeout=""
redirectPort="" /> # 大约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=
-XX:NewRatio=
-Xdebug
-Xnoagent
-Djava.compiler=NONE
-Xrunjdwp:transport=dt_socket,server=y,suspend=n,address="
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 | wc -l # 查看打开数。 2310是tomcat的PID lsof |grep >> .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//limits