tomcat与jetty

相同点:

1.Tomcat和Jetty都是一种Servlet引擎,他们都支持标准的servlet规范和JavaEE的规范
不同点:
架构方面:
Jetty的架构比Tomcat的更为简单
Jetty的架构是基于Handler来实现的,主要的扩展功能都可以用Handler来实现,扩展简单。
Tomcat的架构是基于容器设计的,进行扩展是需要了解Tomcat的整体设计结构,不易扩展。
2.性能方面:
Jetty和Tomcat性能方面差异不大
Jetty可以同时处理大量连接而且可以长时间保持连接,适合于web聊天应用等等。
Jetty的架构简单,因此作为服务器,Jetty可以按需加载组件,减少不需要的组件,减少了服务器内存开销,从而提高服务器性能。
Jetty默认采用NIO结束在处理I/O请求上更占优势,在处理静态资源时,性能较高
Tomcat适合处理少数非常繁忙的链接,也就是说链接生命周期短的话,Tomcat的总体性能更高。
Tomcat默认采用BIO处理I/O请求,在处理静态资源时,性能较差。
3.其它比较
Jetty的应用更加快速,修改简单,对新的Servlet规范的支持较好。
Tomcat目前应用比较广泛,对JavaEE和Servlet的支持更加全面,很多特性会直接集成进来。

jetty优化

1.cd /home/jetty
vim start.ini [jetty调优文件] -内存调优
cd /home/jetty/etc
vim jetty.xml [jetty调优文件] -jvm参数
cd/home/jetty/bin
vim jetty.sh[jetty调优文件] -JAVA_OPTIONS里参数调整(内存占用)
cd /home/jetty/etc
vim jetty.xml [jetty调优文件] -配置最大线程数(当内存和性能够用的时候)
还可以设置最多同时处理的连接数 maxThreads和acceptCount的值

从start.ini角度:

-module=jmx
-module=jmx-remote
-Xms2G -Xmx2G
-XX:SurvivorRatio=32
-XX:MaxTenuringThreshold=5
-XX:+UseParNewGC
-XX:+UseConcMarkSweepGC
-XX:+UseCMSCompactAtFullCollection
-XX:CMSFullGCsBeforeCompaction=0
-XX:+CMSClassUnloadingEnabled
-XX:+CMSClassUnloadingEnabled
-XX:+CMSParallelRemarkEnabled
-XX:CMSInitiatingOccupancyFraction=85
-XX:SoftRefLRUPolicyMSPerMB=0
-XX:-ReduceInitialCardMarks
-Dsun.rmi.dgc.client.gcInterval=3600000
-Dsun.rmi.dgc.server.gcInterval=3600000
-XX:PermSize=512M
-XX:MaxNewSize=512M
-XX:MaxPermSize=512M

从jetty.xml 角度:

jvm

-Xms:设置jvm内存的初始大小  3550M[可以与最大的内存相等]
-Xmx:设置jvm内存的最大值     3550M[峰值]
-Xmn:年轻代大小为2G,堆大小=年轻代大小 + 年老代大小 + 持久代大小 持久代一般固定大小为64m,
           所以增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。
-Xss:设置每个线程的堆栈大小(也就是说,在相同物理内存下,减小这个值能生成更多的线程)
-XX:NewRatio :设置新域与旧域之比,如-XX:NewRatio = 4就表示新域与旧域之比为1:4
-XX:NewSize:设置新域的初始值
-XX:MaxNewSize :设置新域的最大值
-XX:PermSize:设置永久域的初始值
-XX:MaxPermSize:设置永久域的最大值
-XX:SurvivorRatio=n:设置新域中Eden区与两个Survivor区的比值。

配置最大线程数(当内存和性能够用的时候)
还可以设置最多同时处理的连接数 maxThreads和acceptCount的值  

当系统的内存和性能够用的时候,我们可以修改jetty的最大线程数来实现提高单台系统的最高并发
<Set name="minThreads">60</Set>
<Set name="maxThreads">600</Set>

从jetty.sh角度:

JAVA_OPTIONS=
"-server 
-Xms:6G 
-Xmx:6G 
-Xmn2G 
-XX:SurvivorRatio=32 
-XX:MaxTenuringThreshold=5 
-XX:+UseParNewGC 
-XX:+UseConcMarkSweepGC 
-XX:+UseCMSCompactAtFullCollection 
-XX:CMSFullGCsBeforeCompaction=0 
-XX:+CMSClassUnloadingEnabled 
-XX:+CMSClassUnloadingEnabled 
-XX:+CMSParallelRemarkEnabled 
-XX:CMSInitiatingOccupancyFraction=85 
-XX:SoftRefLRUPolicyMSPerMB=0 
-XX:-ReduceInitialCardMarks 
-Dsun.rmi.dgc.client.gcInterval=3600000 
-Dsun.rmi.dgc.server.gcInterval=3600000"

可以参考的优秀链接:
调优思路:https://blog.csdn.net/xiaoliuliu2050/article/details/52880348
jvm调优:https://blog.csdn.net/u014351782/article/details/53098227
线上环境调优方案:http://www.imooc.com/article/details/id/253533

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值