复杂性的代价:
系统架构上的复杂性,如果并非出于必要,则一定是坏事.
它的影响主要:
1 . 带来大量不必要的代码,这些代码的每一行都需要编写,测试,而且需要带来很大的维护成本
2. 复杂的架构,往往也意味着性能的低下。
3. 复杂的架构往往会使构建比较复杂,并且往往依赖于一些复杂的工具.
4. 复杂的代码难于理解,也就是说,你很难往这的项目中再添加人员,要理解、维护这些代码,成本之大将超过预期收益.
XP 对于复杂性的理念是: 选择能够奏效的最简单的做法.
再来看看,导致复杂性架构的原因有哪些?
1. 使用复杂的技术解决方案,比如以前的EJB
2. 将对象分布化:
将对象分布化常常会诱发以下几个复杂的情况:
(1) 你需要在不同的服务器中传输对象,若是需要传输一个复杂层级的对象,将会非常困难.
(2) 分布式应用的部署将会非常的复杂,和难于监控.我们需要在不同节点之间保持代码同步,所以在一个集群上部署新的二进制程序将会是非常复杂的
(3) 所有远程调用都需要面对网络问题,对于类似的异常处理,也是增加复杂度的方面之一
(4) 对于分布式代码的测试变得异常复杂,因为要测试多种故障场景以及形形色色的部署现场.
另:
在人们中有一种广为传播的信念:分布式应用系统是高度可扩展的,这也是支持对象分布化的主要论点。
但是事实是,这基本是一个神话。 人们认为可以通过 4个tomcat容器,8个EJB容器来扩展应用,所有请求都通过WEB层来进行远程调用。
这里的主要问题是: 每次远程调用消耗的性能过于高,将设理论上这样的调用真是有所收益的话,也早被网络消耗光拉。
我们更加倾向于: 将应用完整镜像到一个集群,每个镜像放在集群中的机器上,用同一个JVM来跑应用,通过硬件或者web容器的负载均衡技术来对前台的请求来进行分流。让每个机器上的代码都相同,而且每一个应用都是跑在各自机器的一个JVM实例中,这样的效率要远远高于分布式应用.
3.模式病
系统架构过于偏向于模式的应用,生搬硬套,导致应用过于复杂
4.各个软件厂商的忽悠
厂商将复杂的应用以最佳实践方式放出来,以显示他们的产品又多强大,但是往往他们给的最佳实践或许对真正的需求帮助并不大,反而会将应用架构带入泥潭
结论: 借用quick sort作者,也是图灵奖获得者C.H.A.R.Hoare的一句有深意的话来说:
“有两种软件开发的方法:一种是尽量把事情做得简单,让人一看就知道系统明显没有缺陷;一种是把事情尽量复杂,这样一来,也就没有明显的缺陷。”
分享到:
相关推荐
【标题】:“非常简单的J2EE购物车” 【描述】:“非常简单的J2EE购物车是一个基础的电子商务项目,旨在帮助初学者理解J2EE技术在构建web应用程序时的应用,特别是如何实现一个基本的购物车功能。这个项目可能涵盖...
【J2EE简单留言版系统】是一个基于Java企业级应用平台(Java 2 Platform, Enterprise Edition,简称J2EE)开发的在线互动平台。该系统实现了基础的用户功能,包括用户登录、注册以及留言交流。在这样的系统中,...
关于j2ee的介绍包括一些J2EE初学者需要注意的问题和基本的框架
这个“J2EE简单实例”很可能是为了帮助初学者理解和学习J2EE的核心概念和应用。尽管描述中提到存在一些BUG,这反而是学习过程中的常见情况,通过调试和修复问题,初学者可以深化对J2EE的理解。 J2EE平台由一系列...
8. **安全性**:J2EE提供了安全机制,如JAAS(Java Authentication and Authorization Service),用于处理用户认证和授权,保护聊天室免受未经授权的访问。 9. **Web容器**:为了运行J2EE应用,需要一个支持J2EE...
【标题】:“简单的J2EE项目” 在Java世界中,J2EE(Java 2 Platform, Enterprise Edition)是一个用于开发和部署企业级应用程序的框架。它提供了多种服务、API和工具,以支持分布式多层应用的开发,如Web服务器、...
在J2EE(Java 2 Platform, Enterprise Edition)的web开发中,我们通常涉及到一系列的技术和工具,以构建高效、可扩展的企业级应用程序。这里我们将深入探讨标题和描述中提到的一些关键知识点,包括EL(Expression ...
【标题】"自己手写的一个简单的J2EE服务器"揭示了这个项目是一个个人开发的、遵循J2EE标准的应用服务器实现。J2EE,全称为Java 2 Platform, Enterprise Edition,是Java平台的企业版,主要用于构建分布式、多层的...
J2EE的核心在于其分层架构,这使得应用程序可以被分解为多个独立的组件,每个组件负责特定的功能,从而实现高可扩展性、可维护性和可靠性。 1. **J2EE架构** J2EE架构主要由以下几层构成: - **客户端层(Client ...
可能包括创建简单的Servlet响应、JSP动态网页、EJB的使用,以及如何进行数据库操作、事务管理和安全配置等内容。这些实例将帮助初学者快速理解和掌握J2EE开发。 **5. 学习J2EE的好处** - 广泛支持:许多大型企业和...
一个J2EE例子可能涉及到银行转账,其中必须确保转账操作的原子性,即使在系统故障的情况下也要保证资金的安全。 综上所述,这个J2EE程序集包含了一系列关键组件的实例,涵盖了Web层(Servlet、JSP)、业务逻辑层...
JavaBean在JSP中作为组件使用,提高了代码的重用性和维护性。 这些实验综合起来,展示了Java与J2EE架构中的重要组成部分,包括前端的jQuery和jQuery UI,以及后端的JSP、Servlet和JavaBean。通过这些实践,开发者...
- **创建J2EE应用程序**:从搭建开发环境开始,一步步创建一个简单的J2EE应用程序。 - **企业Bean的使用**:详细介绍如何创建和使用EJB(Enterprise JavaBeans),包括会话Bean、实体Bean和消息驱动Bean。 - **...
J2EE 6.0引入了注解驱动的依赖注入(DI),通过Java EE容器自动管理对象的生命周期和依赖关系,简化了代码,提高了可测试性和可维护性。例如,使用`@EJB`、`@Inject`和`@ManagedBean`等注解,可以方便地实现服务...
J2EE 6.0是该平台的一个重要版本,它引入了许多改进和新特性,以提高开发效率和应用的可维护性。这个名为“J2EE_6.0_jar包”的压缩文件很可能是为了支持J2EE 6.0环境下的开发工作而提供的。 在描述中提到的"spring ...
【标题】: "简单聊天室 J2EE课程实验 - 使用Servlet实现" 【描述】: "在J2EE课程中,构建一个简单的聊天室是学习Web应用程序开发基础的一个常见实践项目。这个实验旨在让学生掌握Servlet技术,理解HTTP协议,并能够...
2. **开发第一个Java应用程序**:在MyEclipse中新建一个Java项目,编写简单的Java代码,理解类、对象、方法等基本概念。 3. **Eclipse的配置使用**:掌握如何在Eclipse中设置工作空间、配置构建路径、管理项目依赖...