欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

轻量级框架与重量级框架

程序员文章站 2022-03-09 18:47:26
...

事实上“轻量级”与“重量级”并没有确切的定义。轻重量级之分应当考虑如下几个方面:

 

加载的资源

Spring相对于EJB是轻量级的,但这就好像说大象比鲸轻。

如果你想要运行一个Java EE应用程序,你不能够简单地创建一个应用并直接运行它本身。需要一个JavaEE服务器来运行应用,例如Glassfish,WebLogic或WebSphere。多数应用服务器都是非常巨大并且复杂的,并不容易安装和配置。

 

EJB应用启动时要消耗大量的资源,内存、CPU等,把所有的服务都加载进来;Spring则是可定制服务,需要什么加载什么。

 

侵入性(或曰框架依赖性,耦合性)

重量级框架(如EJB2.0和Struts1.2)侵入性较高。它强制开发者写一些与框架绑定的类。这使得这些类很难被测试。

Spring将侵入性降到最低,它允许使用POJO进行开发。Spring并不强制实现Spring API接口或扩展Spring API类。这使得这些类方便测试。这使得把类迁移到其他轻量级容器更加容易。

 

开发的方便程度

如上条所述,使用重量级框架要写一些框架绑定的类,部署、运行及测试过程都较为复杂,开发起来并不方便。而轻量级框架反之。

 

解决问题的侧重点不同:

轻量级框架侧重于减小开发的复杂度,相应它的处理能力较弱(事务功能弱,不具备分布式处理能力),适用于开发中小型企业应用。 重量级框架则强调高可伸缩性,适合于开发大型企业应用。

 

轻量级框架的特点:

一般是非侵入性的、依赖的东西非常少,占用资源非常少,部署简单,比较容易使用。

 

为何说Spring是轻量级框架:

  • Spring以集中的、自动化的方式进行应用程序对象创建和装配,管理对象生命周期,组合成复杂的应用程序。
  • Spring提供了不同的模块,基于需求可以灵活选择。Spring jar的大小通常在几MB。
  • 相比较EJB,Spring需要写更少的代码和更少的配置。使得开发人员能够更关注业务逻辑。
  • Spring容器是非侵入性的,完全采用POJO进行开发,方便测试。
  • Spring方便与其他框架与第三方类库无缝集成。

Spring与其他基于POJO的容器相比,例如Guice和Plexus,仍然称得上是“重量级”。因为完整的Spring技术栈包含了POJO之上的层次,它的MVC框架需要Servlets基础设施。

Spring相比EJB2.x确实是轻量级,最主要的卖点是POJO的使用。

 

为何说EJB是重量级框架?

首先这是Rod Johnson说的,Spring*者奉之为圭臬的论断。

2004年以前EJB2.x确实是重量级,它需要EJB容器来运行,需要加载较多的资源,代码侵入性较高–需要实现特定的EJB接口,相对来说开发并不方便。

 

总结

轻重量级是相对的,主要从加载资源、代码侵入性和开发便捷性等方面去考虑和比较。类似地,使用volatile变量可以用来确保变量的更新操作被同步到其他线程,这种同步机制相对于同步容器就是轻量级的(当然更具可伸缩性和实用性的是并发容器而非上述二者);而jetty相对于tomcat而言,由于其加载资源更少,也可以称之为轻量级的。

 

Original Link