企业必会技能 tomcat

摘要

Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta项目中的一个核心项目,由Apache、Sun和其他一些公司及个人共同开发而成。由于有了Sun 的参与和支持,最新的Servlet 和JSP规范总是能在Tomcat 中得到体现,Tomcat 5支持最新的Servlet 2.4 和JSP..

企业必会技能 tomcat

tomcat


一、什么是Tomcat?

  Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta项目中的一个核心项目,由Apache、Sun和其他一些公司及个人共同开发而成。由于有了Sun 的参与和支持,最新的Servlet 和JSP规范总是能在Tomcat 中得到体现,Tomcat 5支持最新的Servlet 2.4 和JSP
2.0 规范。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。   
  Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。对于一个初学者来说,可以这样认为,当在一台机器上配置好Apache 服务器,可利用它响应HTML(标准通用标记语言下的一个应用)页面的访问请求。实际上Tomcat 部分是Apache 服务器的扩展,但它是独立运行的,所以当你运行tomcat 时,它实际上作为一个与Apache 独立的进程单独运行的。   
  诀窍是,当配置正确时,Apache 为HTML页面服务,而Tomcat 实际上运行JSP 页面和Servlet。另外,Tomcat和IIS等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Servlet和JSP容器,独立的Servlet容器是Tomcat的默认模式。不过,Tomcat处理静态HTML的能力不如Apache服务器。目前Tomcat最新版本为9.0。

Apache软件基金会:http://apache.org/index.html#projects-list


二、Tomcat版本及其区别介绍

TOMCAT版本的区别主要反映在两个方面:

1. Tomcat本身的技术演进,包括性能的不断提高,功能的增加增强,甚至于重构
2. 因为Tomcat本身是块Servlet容器的试验田,所以他的版本是跟Servlet和JSP的规范一起发展

可以参考官方文档: 此处是链接
----

三、Tomcat 安装

tomcat 6.x
tomcat 7.x
tomcat 8.x
tomcat 9.x

环境准备

  1. [root@abcdocker ~]# /etc/init.d/iptables stop
  2. [root@abcdocker ~]# getenforce
  3. Disabled
  4. #提示:因为tomcat是主要跑程序的,内存是需要比较大的。如果我们本地测试可以设置低一点

安装JDK
tomcat运行需要JDK支持

  1. 下载安装http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
  2. 配置Java环境
  3. # tar zxf jdk-8u91-linux-x64.tar.gz -C /usr/local/
  4. # ln –s /usr/local/jdk1.8.0_91 /usr/local/jdk
  5. # vim /etc/profile
  6. export JAVA_HOME=/usr/local/jdk
  7. export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
  8. export PATH=$JAVA_HOME/bin:$PATH
  9. # source /etc/profile
  10. 看到如下信息,java环境配置成功
  11. # java -version
  12. java version "1.8.0_91"
  13. Java(TM) SE Runtime Environment (build 1.8.0_91-b14)
  14. Java HotSpot(TM) 64-Bit Server VM (build 25.91-b14, mixed mode)

温馨提示: JDK版本最好对应tomcat版本(可能会出现不兼容现学)

安装Tomcat

  1. [root@abcdocker ~]# wget http://mirrors.hust.edu.cn/apache/tomcat/tomcat-8/v8.5.13/bin/apache-tomcat-8.5.13.tar.gz
  2. [root@abcdocker ~]# tar xf apache-tomcat-8.5.13.tar.gz -C /usr/local/
  3. [root@abcdocker ~]# mv /usr/local/apache-tomcat-8.5.13.tar.gz/ /usr/local/tomcat
  4. 启动
  5. [root@abcdocker ~]# /usr/local/tomcat/bin/startup.sh && tailf /usr/local/tomcat/logs/catalina.out
  6. #这样启动是为了方便看日志
  7. tomcat启动停止脚本
  8. # 启动startup.sh
  9. # 停止shutdown.sh

访问路径:http://ip:8080 (默认8080端口)
image_1bccglg2kmui1nj11td171u10j513.png-201.9kB

提示: 更详细的tomcat配置可以参考http://www.zyops.com/java-tomcat
本文只是对几个比较重要的配置文件进行讲解


四、修改配置文件

tomcat配置文件路径/tomcat/bin/server.xml

  1. # shutdown指定终止Tomcat服务器运行时,发给Tomcat服务器的shutdown监听端口的字符串.该属性必须设置
  2. <Server port="8005" shutdown="SHUTDOWN">
  3. <Listener className="org.apache.catalina.startup.VersionLoggerListener" />
  4. <!-- Security listener. Documentation at /docs/config/listeners.html
  5. <Listener className="org.apache.catalina.security.SecurityListener" />
  6. -->
  7. <!--APR library loader. Documentation at /docs/apr.html -->
  8. <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
  9. <!-- Prevent memory leaks due to use of particular java/javax APIs-->
  10. <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
  11. <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
  12. <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />

service服务配置

  1. <Connector port="8221" protocol="HTTP/1.1" #port 端口配置
  2. connectionTimeout="20000" #connectionTimeout指定超时的时间数(以毫秒为单位)
  3. maxThreads="3000" #tomcat起动的最大线程数,即同时处理的任务个数,默认值为200
  4. minSpareThreads="100"      #初始化时创建的线程数
  5. acceptCount="800" #指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理
  6. maxKeepAliveRequests="200"  #表示该连接最大支持的请求数。超过该请求数的连接也将被关闭(此时就会返回一个Connection: close头给客户端)。
  7. URIEncoding="UTF-8"     #指定字符集
  8. redirectPort="8443" /> #指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号

五、设置Tomcat 内存限制

优化catalina.sh配置文件。在catalina.sh配置文件中添加以下代码:

  1. JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1024m -XX:NewSize=512m -XX:MaxNewSize=512m -XX:PermSize=512m -XX:MaxPermSize=512m"
  2. server:一定要作为第一个参数,在多个CPU时性能佳
  3. -Xms:初始堆内存Heap大小,使用的最小内存,cpu性能高时此值应设的大一些
  4. -Xmx:初始堆内存heap最大值,使用的最大内存
  5. 上面两个值是分配JVM的最小和最大内存,取决于硬件物理内存的大小,建议均设为物理内存的一半。
  6. -XX:PermSize:设定内存的永久保存区域
  7. -XX:MaxPermSize:设定最大内存的永久保存区域
  8. -XX:MaxNewSize:
  9. -Xss 15120 这使得JBoss每增加一个线程(thread)就会立即消耗15M内存,而最佳值应该是128K,默认值好像是512k.
  10. +XX:AggressiveHeap 会使得 Xms没有意义。这个参数让jvm忽略Xmx参数,疯狂地吃完一个G物理内存,再吃尽一个Gswap
  11. -Xss:每个线程的Stack大小
  12. -verbose:gc 现实垃圾收集信息
  13. -Xloggc:gc.log 指定垃圾收集日志文件
  14. -Xmnyoung generationheap大小,一般设置为Xmx34分之一
  15. -XX:+UseParNewGC :缩短minor收集的时间
  16. -XX:+UseConcMarkSweepGC :缩短major收集的时间

例子:我公司服务器Tomcat内存设置如下
服务器硬件:2核8G
tomcat实例:3个tomcat实例

  1. JAVA_OPTS="-server -Xms2048m -Xmx4096m"

六、Tomcat获取用户IP地址

在tomcat配置文件/conf/server.xml下配置

  1. <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
  2. prefix="localhost_access_log" suffix=".txt"
  3. pattern="%h %l %u %t %r %s %b" />
  4. 前面有负载均衡的时候,获取真实IP可以使用下面的配置
  5. <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
  6. prefix="localhost_access_log." suffix=".txt"
  7. pattern="%{X-Forwarded-For}i %h %l %u %t %r %s %b" />

七、tomcat启动停止脚本

考虑到Tomcat启动每次需要手动比较麻烦,我们这有写好的启动脚本

  1. #!/bin/bash
  2. # chkconfig: 2345 74 44
  3. # description: Tomcat is a Java Servlet Container
  4. . /etc/profile
  5. TOMCAT_HOME=/usr/local/tomcat
  6. start () {
  7. TOMCAT_PID=`ps -ef |grep "$TOMCAT_HOME" |grep -v "grep" |awk '{print $2}'`
  8. if [ -z $TOMCAT_PID ];then
  9. /bin/bash $TOMCAT_HOME/bin/startup.sh
  10. else
  11. echo "$0 is running"
  12. fi
  13. }
  14. stop () {
  15. TOMCAT_PID=`ps -ef |grep "$TOMCAT_HOME" |grep -v "grep" |awk '{print $2}'`
  16. if [ -z $TOMCAT_PID ];then
  17. echo "$0 is not running"
  18. else
  19. echo "shutting down $0"
  20. kill -9 "$TOMCAT_PID" && echo "PID $TOMCAT_PID killed."
  21. fi
  22. }
  23. status () {
  24. TOMCAT_PID=`ps -ef |grep "$TOMCAT_HOME" |grep -v "grep" |awk '{print $2}'`
  25. if [ -z $TOMCAT_PID ];then
  26. echo "$0 is not running"
  27. else
  28. echo "$0 is running PID is $TOMCAT_PID"
  29. fi
  30. }
  31. case $1 in
  32. start)
  33. start
  34. #tail -f $TOMCAT_HOME/logs/catalina.out
  35. ;;
  36. stop)
  37. stop
  38. ;;
  39. status)
  40. status
  41. ;;
  42. restart)
  43. stop
  44. start
  45. #tail -f $TOMCAT_HOME/logs/catalina.out
  46. ;;
  47. *)
  48. echo "Usage:$0 {start|stop|status|restart}."
  49. ;;
  50. esac

提示: 本脚本不提供log,还需要在脚本后面加上&& tailf logs/catalina.out

Jar包介绍

jar包种类介绍 http://blog.csdn.net/helloxiaoliang/article/details/39030909

 很多时候开发会给我们一个jar包,让我们进行运行.启动命令如下:
jar 包启动

  1. [root@tomcat univ-public]# nohup java -jar jar包名称.jar > user.out &
  2. #具体不介绍了,百度去吧

关于监控jXM可以参考以下文章:
Zabbix 3.0 生产案例 [四]
jvisualvm 远程监控Linux下的tomcat
linux下的java远程调试jpda+tomcat


新闻联播老司机

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: