复杂性的代价:
系统架构上的复杂性,如果并非出于必要,则一定是坏事.
它的影响主要:
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简单购物系统详解** 在IT领域,J2EE(Java 2 Platform, Enterprise Edition)是一个广泛使用的开源框架,用于构建企业级的分布式应用系统。本项目名为"J2EE简单购物(含数据库)",是基于Struts框架和SQL ...
这个“J2EE简单实例”很可能是为了帮助初学者理解和学习J2EE的核心概念和应用。尽管描述中提到存在一些BUG,这反而是学习过程中的常见情况,通过调试和修复问题,初学者可以深化对J2EE的理解。 J2EE平台由一系列...
标题“flex 与 j2ee 简单集成”指的是将Adobe Flex技术与Java Enterprise Edition (J2EE)平台相结合,实现前端用户界面与后端服务器功能的交互。Flex是一种用于构建富互联网应用程序(RIA)的开发框架,它基于...
**DWR-J2EE简单例子详解** DWR (Direct Web Remoting) 是一个开源的Java库,它允许在Web应用程序中实现JavaScript与服务器端Java代码的双向通信。DWR简化了AJAX(Asynchronous JavaScript and XML)应用的开发,...
【J2EE基础-简单的电子商务网站】 在信息技术领域,J2EE(Java 2 Platform, Enterprise Edition)是一种广泛应用于企业级应用开发的平台,它由Sun Microsystems(现已被Oracle收购)开发并维护。J2EE提供了多种服务...
【标题】:“简单的J2EE项目” 在Java世界中,J2EE(Java 2 Platform, Enterprise Edition)是一个用于开发和部署企业级应用程序的框架。它提供了多种服务、API和工具,以支持分布式多层应用的开发,如Web服务器、...
6. **容器管理**:J2EE服务器如Tomcat或Glassfish提供了运行环境,管理EJB的生命周期、事务处理、安全性等。在简单的项目中,你将了解如何配置和使用这些服务。 7. **部署描述符**:如`web.xml`文件,这是Web应用的...
在J2EE(Java 2 Platform, Enterprise Edition)的web开发中,我们通常涉及到一系列的技术和工具,以构建高效、可扩展的企业级应用程序。这里我们将深入探讨标题和描述中提到的一些关键知识点,包括EL(Expression ...
总结来说,简单工厂模式提供了一种静态方法来创建对象,使得客户端可以避免直接与产品类的实例化过程耦合,提高了代码的可读性和可维护性。同时,通过修改工厂类的内部逻辑,可以轻松地添加或移除支持的产品类型,...
【J2EE实现的简单图书管理系统】 在信息技术领域,J2EE(Java 2 Platform, Enterprise Edition)是一种广泛使用的开源企业级应用开发平台,尤其适合构建分布式、多层架构的应用程序,如我们的“简单的图书管理系统...
在本次实验中,学生们被要求使用J2EE技术,特别是SSH(Struts2、Hibernate、Spring)框架,来构建一个简单的在线学习系统。这个实验的主要目标是让学生们熟悉并掌握Struts2框架的基本使用方法,包括如何利用框架设计...
在J2EE 1.4中,JMS被用来实现解耦和可靠的消息传递,提高系统的可伸缩性和灵活性。 ### 5. Java Transaction API (JTA) JTA定义了一种标准接口,用于管理跨越多个资源(如数据库、消息队列)的事务。在J2EE环境中,...
【标题】"j2EE知识用MyEclipse编写的简单的BBS论坛"涉及的主要知识点是基于Java企业版(Java 2 Platform, Enterprise Edition,简称J2EE)的Web应用程序开发,利用MyEclipse集成开发环境(Integrated Development ...
此外,这份资源可能还会讨论如何与其他技术如Spring Framework、Hibernate(ORM工具)集成,以增强J2EE应用的性能和可维护性。Spring提供了依赖注入和面向切面编程等功能,而Hibernate则简化了数据库操作,让Java...
JavaBean在JSP中作为组件使用,提高了代码的重用性和维护性。 这些实验综合起来,展示了Java与J2EE架构中的重要组成部分,包括前端的jQuery和jQuery UI,以及后端的JSP、Servlet和JavaBean。通过这些实践,开发者...
在学习这些知识点时,通常会通过实例来加深理解,例如创建一个简单的登录注册系统,使用Servlet处理用户请求,JSP展示页面,EJB处理业务逻辑,JDBC或JPA进行数据访问,JNDI查找资源,以及应用安全策略。通过这些实例...
10. **JAX-RS(Java API for RESTful Web Services)**:定义了创建RESTful服务的API,使得开发Web服务变得更加简单。 此外,非标准的规范,如Struts、Spring框架、Hibernate ORM等,虽然不是J2EE官方的一部分,但...
总之,这份【J2EE实验代码2】资源对于初学者和经验丰富的开发者来说都是宝贵的财富,它提供了实践J2EE技术的机会,有助于提升技能和理解企业级开发的复杂性。建议大家积极收集并深入研究,这将对个人的IT职业生涯...
在IT行业中,J2EE(Java 2 ...综上所述,"j2ee文件上传下载局域网网站"项目涵盖了J2EE的多个关键技术和概念,包括文件操作、网络通信、安全性、数据库交互以及前端开发,是学习和实践J2EE技术的一个典型应用场景。
- **J2EE技术回顾**:J2EE技术平台在企业级应用开发领域取得了显著的成功,其标准化的特点极大地促进了开发的开放性和互操作性。但随着技术的发展,J2EE也暴露出一些问题。 - **存在的问题**: - 复杂性:J2EE系统...