Tomcat之面试专题

未更完,待整理

1、Tomcat 的缺省端口是多少,怎么修改?

1)找到 Tomcat 目录下的 conf 文件夹
2)进入 conf 文件夹里面找到 server.xml 文件
3)打开 server.xml 文件
4)在 server.xml 文件里面找到下列信息

<Connector connectionTimeout="20000" 
port="8080" 
protocol="HTTP/1.1" 
redirectPort="8443" 
uriEncoding="utf-8"/>
port="8080"
//改成你想要的端口

2、Tomcat 有几种部署方式?

1)直接把 Web 项目放在 webapps 下,Tomcat 会自动将其部署
2)在 server.xml 文件上配置节点,设置相关的属性即可
3)通过 Catalina 来进行配置:进入到 conf\Catalina\localhost 文件下,创建一个 xml 文件,该文件的名字就是站点的名字。
编写 XML 的方式来进行设置。

3.Tomcat 工作模式

Tomcat 是一个 JSP/Servlet 容器。其作为 Servlet 容器,有三种工作模式:独 立的 Servlet 容器、进程内的 Servlet 容器和进程外的 Servlet 容器。
进入 Tomcat 的请求可以根据 Tomcat 的工作模式分为如下两类:
Tomcat 作为应用程序服务器:请求来自于前端的 web 服务器,这可能是 Apache, IIS, Nginx 等;
Tomcat 作为独立服务器:请求来自于 web 浏览器;

4、tomcat 容器是如何创建 servlet 类实例?用到了什么原理?

当容器启动时,会读取在 webapps 目录下所有的 web 应用中的 web.xml 文件,然后对 xml 文件进行解析,
并读取 servlet 注册信息。然后,将每个应用中注册的 servlet 类都进行加载,并通过反射的方式实例化。
(有时候也是在第一次请求时实例化)在 servlet 注册时加上如果为正数,则在一开始就实例化,
如果不写或为负数,则第一次请求实例化。

5.内存调优

内存方式的设置是在 catalina.sh 中,调整一下 JAVA_OPTS 变量即可,因为后
面的启动参数会把 JAVA_OPTS 作为 JVM 的启动参数来处理。
具体设置如下:
JAVA_OPTS="$JAVA_OPTS -Xmx3550m -Xms3550m -Xss128k -
XX:NewRatio=4 -XX:SurvivorRatio=4"

其各项参数如下:
-Xmx3550m:设置 JVM 最大可用内存为 3550M。
-Xms3550m:设置 JVM 促使内存为 3550m。此值可以设置与-Xmx 相同,以
避免每次垃圾回收完成后 JVM 重新分配内存。
-Xmn2g:设置年轻代大小为 2G。整个堆大小=年轻代大小 + 年老代大小 +
持久代大小。持久代一般固定大小为 64m,所以增大年轻代后,将会减小年老
代大小。此值对系统性能影响较大,Sun 官方推荐配置为整个堆的 3/8。
-Xss128k:设置每个线程的堆栈大小。JDK5.0 以后每个线程堆栈大小为 1M,
以前每个线程堆栈大小为 256K。更具应用的线程所需内存大小进行调整。在相
同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的
线程数还是有限制的,不能无限生成,经验值在 3000~5000 左右。
-XX:NewRatio=4:设置年轻代(包括 Eden 和两个 Survivor 区)与年老代的比
值(除去持久代)。设置为 4,则年轻代与年老代所占比值为 1:4,年轻代占
整个堆栈的 1/5
-XX:SurvivorRatio=4:设置年轻代中 Eden 区与 Survivor 区的大小比值。设置
为 4,则两个 Survivor 区与一个 Eden 区的比值为 2:4,一个 Survivor 区占整
个年轻代的 1/6
-XX:MaxPermSize=16m:设置持久代大小为 16m。
-XX:MaxTenuringThreshold=0:设置垃圾最大年龄。如果设置为 0 的话,则年
轻代对象不经过 Survivor 区,直接进入年老代。对于年老代比较多的应用,可
以提高效率。如果将此值设置为一个较大值,则年轻代对象会在 Survivor 区进
行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收
的概论。

6.共享 session 处理

目前的处理方式有如下几种:
1).使用 Tomcat 本身的 Session 复制功能
参考 http://ajita.iteye.com/blog/1715312(Session 复制的配置)
方案的有点是配置简单,缺点是当集群数量较多时,Session 复制的时间会比
较长,影响响应的效率
2).使用第三方来存放共享 Session
目前用的较多的是使用 memcached 来管理共享 Session,借助于
memcached-sesson-manager 来进行 Tomcat 的 Session 管理
参考 http://ajita.iteye.com/blog/1716320(使用 MSM 管理 Tomcat 集群
session)
3).使用黏性 session 的策略
对于会话要求不太强(不涉及到计费,失败了允许重新请求下等)的场合,同
一个用户的 session 可以由 nginx 或者 apache 交给同一个 Tomcat 来处理,这
就是所谓的 session sticky 策略,目前应用也比较多
参考:(tomcat session sticky)
nginx 默认不包含 session sticky 模块,需要重新编译才行(windows 下我也不
知道怎么重新编译)
优点是处理效率高多了,缺点是强会话要求的场合不合适

7.添加 JMS 远程监控

对于部署在局域网内其它机器上的 Tomcat,可以打开 JMX 监控端口,局域网
其它机器就可以通过这个端口查看一些常用的参数(但一些比较复杂的功能不
支持),同样是在 JVM 启动参数中配置即可,配置如下:
-Dcom.sun.management.jmxremote.ssl=false -
Dcom.sun.management.jmxremote.authenticate=false

-Djava.rmi.server.hostname=192.168.71.38 设置 JVM 的 JMS 监控监听的 IP
地址,主要是为了防止错误的监听成 127.0.0.1 这个内网地址
-Dcom.sun.management.jmxremote.port=1090 设置 JVM 的 JMS 监控的端口
-Dcom.sun.management.jmxremote.ssl=false 设置 JVM 的 JMS 监控不实用
SSL
-Dcom.sun.management.jmxremote.authenticate=false 设置 JVM 的 JMS 监
控不需要认证

8.专业点的分析工具有

IBM ISA,JProfiler、probe 等,具体监控及分析方式去网上搜索即可

9.关于 Tomcat 的 session 数目

这个可以直接从 Tomcat 的 web 管理界面去查看即可 ;
或者借助于第三方工具 Lambda Probe 来查看,它相对于 Tomcat 自带的管理
稍微多了点功能,但也不多 ;

10.监视 Tomcat 的内存使用情况

使用 JDK 自带的 jconsole 可以比较明了的看到内存的使用情况,线程的状态,
当前加载的类的总量等;
JDK 自带的 jvisualvm 可以下载插件(如 GC 等),可以查看更丰富的信息。
如果是分析本地的 Tomcat 的话,还可以进行内存抽样等,检查每个类的使用
情况

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值