Jetty和Tomcat
最近在学习Gitee里面的Star项目,发现有些项目已经开始使用Jetty,大致查了一下发现,Google已经放弃了Tomcat,把一些服务迁移到了Jetty上,对于这个黑马,我挺感兴趣的,所以把它的大致情况也整理分享下:
Jetty是什么,背后是哪家公司提供技术支持?(部分解释来自其官网)
如果我们在网上搜索会发现,其实Jetty的全称是Eclipse Jetty,它是Eclipse提供的Web服务器和javax.servlet容器,以及对HTTP / 2,WebSocket,OSGi,JMX,JNDI,JAAS和许多其他集成的支持。这些组件是开源的,可用于商业用途和分发。
Eclipse Jetty用于开发和生产中的各种项目和产品。Jetty可以轻松嵌入到设备,工具,框架,应用程序服务器和集群中。有关Jetty的更多用途,请参阅Jetty Powered页面。
目前推荐使用的版本是Jetty 9,可以在Jetty下载页面上获得。 另外还有Jetty 8和Jetty 7的最新维护版本,
Jetty项目自2009年以来一直在Eclipse基金会托管。在此之前,Jetty的早期版本部分或完全存在于Codehaus和Sourceforge的Jetty项目中。其特征及应用大致说明如下:
具体的下载地址是: https://www.eclipse.org/jetty/download.html
关于Jetty在Windows下的安装部署可详细访问以下CDSN伙伴的网站,再次不做赘余介绍:
https://blog.csdn.net/Angelia620/article/details/84636090
Jetty和Tomcat的对比说明:
Jetty更轻量级。这是相对Tomcat而言的。
由于Tomcat除了遵循Java Servlet规范之外,自身还扩展了大量JEE特性以满足企业级应用的需求,所以Tomcat是较重量级的,而且配置较Jetty亦复杂许多。但对于大量普通互联网应用而言,并不需要用到Tomcat其他高级特性,所以在这种情况下,使用Tomcat是很浪费资源的。这种劣势放在分布式环境下,更是明显。换成Jetty,每个应用服务器省下那几兆内存,对于大的分布式环境则是节省大量资源。而且,Jetty的轻量级也使其在处理高并发细粒度请求的场景下显得更快速高效。
jetty更灵活,体现在其可插拔性和可扩展性,更易于开发者对Jetty本身进行二次开发,定制一个适合自身需求的Web Server。相比之下,重量级的Tomcat原本便支持过多特性,要对其瘦身的成本远大于丰富Jetty的成本。用自己的理解,即增肥容易减肥难。
然而,当支持大规模企业级应用时,Jetty也必须要扩展,在这场景下Tomcat便是更优的。
相同点:
Tomcat和Jetty都是一种Servlet引擎,他们都支持标准的servlet规范和JavaEE的规范。
不同点:
架构比较
Jetty的架构比Tomcat的更为简单
Jetty的架构是基于Handler来实现的,主要的扩展功能都可以用Handler来实现,扩展简单。
Tomcat的架构是基于容器设计的,进行扩展是需要了解Tomcat的整体设计结构,不易扩展。
性能比较
Jetty和Tomcat性能方面差异不大
Jetty可以同时处理大量连接而且可以长时间保持连接,适合于web聊天应用等等。
Jetty的架构简单,因此作为服务器,Jetty可以按需加载组件,减少不需要的组件,减少了服务器内存开销,从而提高服务器性能。
Jetty默认采用NIO结束在处理I/O请求上更占优势,在处理静态资源时,性能较高
少数非常繁忙;Tomcat适合处理少数非常繁忙的链接,也就是说链接生命周期短的话,Tomcat的总体性能更高。
Tomcat默认采用BIO处理I/O请求,在处理静态资源时,性能较差。
其它比较
Jetty的应用更加快速,修改简单,对新的Servlet规范的支持较好。
Tomcat目前应用比较广泛,对JavaEE和Servlet的支持更加全面,很多特性会直接集成进来
Jetty的特性及适用场景说明:
根据Jetty的特性分析,我们可以发现,Jetty在互联网企业,分布式环境下,在处理高并发细粒度请求的场景下,更加灵活、高效,同时支持做二次开发,可组件进行灵活的重构或增减
在对于大规模企业级应用时,因Jetty需要进行扩展,而Tomcat则可拿来即用,更方便些。但在云计算等云化服务越来越盛行的时代,相信Jetty会有更加广阔的应用场景,同时其开源、简单、灵活的特性,也会为其更加广泛的应用铺路,小而美,比大而全,会更具有竞争优势
建议:
所以赶快学起来吧,当前阶段可以根据实际需要,自由选择,以业务场景为主要衡量目标
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
MySQL运行原理与基础架构!
下面是关于上述部件的介绍: connectors 与其他编程语言中的sql 语句进行交互,如php、java等。 Management Serveices & Utilities系统管理和控制工具 Connection Pool (连接池)管理缓冲用户连接,线程处理等需要缓存的需求 SQL Interface (SQL接口)接受用户的SQL命令,并且返回用户需要查询的结果。比如select from就是调用SQL Interface Parser (解析器)SQL命令传递到解析器的时候会被解析器验证和解析。 主要功能: a . 将SQL语句分解成数据结构,并将这个结构传递到后续步骤,后面SQL语句的传递和处理就是基于这个结构的 如果在分解构成中遇到错误,那么就说明这个sql语句是不合理的,语句将不会继续执行下去 Optimizer (查询优化器)SQL语句在查询之前会使用查询优化器对查询进行优化(产生多种执行计划,最终数据库会选择最优化的方案去执行,尽快返会结果) 他使用的是“选取-投影-联接”策略进行查询。 用一个例子就可以理解: select uid,name from u...
- 下一篇
什么是T3机房?T1/T2/T3/T4机房等级对比详解
我们在购买IDC服务时都会选择T3机房或者T4机房,那么什么是T3机房?T3机房和T4机房有什么区别?服务器百科网来说说T1/T2/T3/T4机房等级对比详解: IDC机房等级划分 IDC机房的等级划分是根据《数据中心电信基础设施标准》而定的,它是美国国家标准学会(ANSI)颁布的,它将IDC数据中心(大型的设备和管理都比较完善的机房可以称为数据中心)基础设施的可用性定义了四种不同等级,即Tier 1、Tier 2、Tier 3和Tier 4四个等级。 四个等级分别对应数据中心的可用性指标及年平均故障时间: T1机房(通过基本认证):可用性99.671%、年平均故障时间28.8小时; T2机房(通过银级认证):可用性 99.741%、年平均故障时间22小时; T3机房(通过金级认证):可用性 99.982%、年平均故障时间1.6小时; T4机房(通过白金级认证):可用性 99.995%、年平均故障时间0.4小时。相关阅读:IDC双专线静态路由冗余上云方案 Tier等级标准的等级分类 机房等级 详细介绍 T1:基本机房基础设施 a) T1 基本数据中心拥有非冗余容量组件,以及一个单一的非...
相关文章
文章评论
共有0条评论来说两句吧...