
简介
随着现代应用程序变得越来越复杂,需要处理海量数据和用户请求,分布式系统已成为现代软件架构的基石。分布式系统将应用程序组件分散到多个计算机(称为节点)上,使之能够协同工作并提供可靠且可扩展的解决方案。
应用服务器在分布式系统中扮演着至关重要的角色,负责管理应用程序、处理请求、协调组件通信并确保系统可靠性。本文探讨了应用服务器在分布式系统中的作用,以及如何驾驭其强大功能以实现最佳性能和可靠性。
应用服务器的功能
应用服务器提供了一系列功能,使之成为分布式系统部署的理想选择,包括:
- 请求处理:应用服务器负责接收、处理和响应客户请求。它将请求路由到适当的组件,并从组件收集响应,以向客户提供完整的响应。
- 资源管理:应用服务器管理应用程序所需的资源,包括内存、CPU 和网络连接。它负责分配和释放资源,以确保应用程序平稳运行并最大化资源利用率。
- 事务管理:在分布式系统中,事务涉及多个节点的跨组件操作。应用服务器提供事务管理功能,以确保事务的完整性和一致性,即使出现故障。
- 集群管理:为了提高可扩展性和容错性,分布式系统可以部署在跨多个服务器的集群中。应用服务器提供集群管理功能,以协调集群节点之间的通信并确保负载均衡。
-
安全管理:应用服务器提供安全功能,以保护应用程序和数据免受未经授权的访问和恶意攻击。它支持身份最佳性能、扩展性和可靠性。
通过驾驭应用服务器,开发人员和 IT 专业人员可以创建强大且可扩展的分布式系统,满足现代应用程序的严苛需求。
五种常见的软件架构(几种常见软件架构)
在软件项目开发过程中,都有哪些常见的软件架构?
软件产品的架构,通常都是随着业务的发展而不断演变的;我从事软件开发行业也有十余年了,遇到过的软件(企业级应用,我是从事Java开发)架构主要有这么几种:
单体架构架构
总的概括来说,单体架构就是应用所有的功能,只有一个代码包,开发和部署都在一起,这是一种比较传统的架构风格;当然,单体架构也有着诸多的缺点:
SOA架构
因为单体应用架构的种种缺点,已经不能再满足业务需求的时候,于是就出现了SOA架构。
SOA架构的主要思想是把应用程序的模块化组件,通过接口联系起来(接口可以独立于语言、框架、硬件、操作系统);在SOA架构中,有两个主流实现方式:
微服务架构
微服务的产生,也是由于SOA架构的一些缺点,这里再次印证了这句话,【应用架构的演进的过程通常是被业务逼出来的】。
我将持续分享Java开发、架构设计、程序员职业发展等方面的见解,希望能得到你的关注。
软件开发常用的框架有哪些
北京开运联合认为:Creat系列框架(java框架、c++框架、框架、app框架、php框架)是集快速开发+通用权限管理+工作流+即时通讯+微信组件+智能开发+智能报表+手机APP开发等组件于一体的敏捷开发框架。
开发难度小,提高50%以上的工作效率,可无线扩展,轻松开发APP、CRM、OA、ERP、WMS、MIS等。
框架优势
开发周期短:仅用传统开发周期1/3的时间,便可以完成开发任务。
如果您对这个框架刚兴趣,想了解更多相关信息,这里提供最详细的报价,如果你真的想做,可以来这里,这个手技的开始数字是一八七中间的是三儿零最后的是一四二五零,按照顺序组合起来就可以找到,我想说的是,除非你想做或者了解这方面的内容,如果只是凑热闹的话,就不要来了。
开发难度低:仅需初级开发人员,3天内便可上手开发软件。
开发成本低:无需收费中间件,节省大部分时间和人员成本。
无限扩展性:无限扩展组件,满足多种软件应用开发。
无依赖性:对技术人员依赖程度低,新人快速上手,不惧怕人才流动。
界面美观:丰富的精美界面控件,无需专业美工,界面风格高度统一。
运行速度快:自带速度优化处理,无需开发人员操心。
安全性高:自带安全处理,自动查错,避免任何漏洞。
支持多类型数据库:自带多类型数据库接口,满足无缝隙接口对接。
以往,企业软件多是以业务系统划分的“大软件”,为了满足部门级协作的需要,软件由复杂的功能模块组成、工作流程长;“大软件”因为独立开发部署,花费大、周期长,软件之间也很难连通协作。
随着IT基础计算能力的提高、大数据的广泛应用,企业能够将分散的业务软件集成到统一的大平台上;而移动互联网的深度渗透,更迎合了用户对企业软件功能简单化、使用移动化、协作点状化的需求。
这也使得软件框架在各行业内的需求越来越多。
Creat系列数据框架体系立足于企业发展现状和企业建设需求,着眼于企业信息系统集约化建设和信息资源共享融合,在现有企业建设和发展的基础上,借鉴企业内部发展经验,通过运用大数据模式和服务模式创新,不仅将实现企业数据统一部署,基础数据统一集聚,业务数据深度融合,应用数据深入挖掘,主题数据跨行业、跨部门、跨层级共享,更为重要的是通过建立一体化的、弹性可扩展的企业数据架构项目,规范和引导应用项目开发,改变多头共享,无序交换,粗放发展的局面,重塑企业数据环境,构建双向互动、有序交换、深度融合,按需服务、良性循环的集约化企业数据生态圈。
通俗的来说Creat系列数据框架是一套软件半成品,相当于一座建好的毛坯房,主体框架已经建好,样板间已经做好,各类装修材料已经备齐,您只需要根据自己的业务需求来装修完房间就可高价出售。
这款产品非常适合企业管理软件和互联网平台后台系统,开发框架中提供了完善的权限角色管理功能,快速开发功能,工作流引擎功等通用的功能模块,以及可扩展的系统机制,美观简洁的UI界面风格。
什么是架构,SQL中的架构有哪些
架构(Schema)是一组数据库对象的集合,它被单个负责人(可以是用户或角色)所拥有并构成唯一命名空间。
你可以将架构看成是对象的容器。
在SQLServer2000中,用户(User)和架构是隐含关联的,即每个用户拥有与其同名的架构。
因此要删除一个用户,必须先删除或修改这个用户所拥有的所有数据库对象。
在SQLServer2005中,架构和创建它的数据库用户不再关联,完全限定名(fully-qualifiedname)现在包含4个部分
1.体系结构(Architecture)
体系结构亦可称为架构,所谓软件架构,根据Perry和Wolfe之定义:SoftwareArchitecture={Elements,Forms,Rationale/Constraint},也就是软件主架构={组件元素,元素互助合作之模式,基础要求与限制}。
PhilippeKruchten采用上面的定义,并说明主架构之设计就是:将各组件元素以某些理想的合作模式组织起来,以达成系统的基本功能和限制。
体系结构又分为多种样式,如PipesandFilters等。
2.框架(Framework)
框架亦可称为应用架构,框架的一般定义就是:在特定领域基于体系结构的可重用的设计。
也可以认为框架是体系结构在特定领域下的应用。
框架比较出名的例子就是MVC。
3.库(Library)
库应该是可重用的、相互协作的资源的集合,供开发人员进行重复调用。
它与框架的主要区别在于运行时与程序的调用关系。
库是被程序调用,而框架则调用程序。
比较好的库有JDK。
4.设计模式(DesignPattern)
设计模式大家应该很熟悉,尤其四人帮所写的书更是家喻户晓。
“四人帮”将模式描述为“在一定的环境中解决某一问题的方案”。
这三个事物—问题、解决方案和环境—是模式的基本要素。
给模式一个名称,考虑使用模式将产生的结果和提供一个或多个示例,对于说明模式也都是有用的。
5.平台(PlatForm)
由多种系统构成,其中也可以包含硬件部分。
对于以上的概念有一个比较清楚的认识之后,就可以在软件的开发过程中进行应用。
理论和实践是缺一不可的,相辅相成的。
没有理论的指导,实践就缺乏基础;没有实践的证明,理论就缺乏依据,因此我一直认为:对于当代的程序员,在有一定的实践基础后,必须学习更深的理论知识。
无论你是从那方面先开始学习的。
在软件的开发过程中,从许多过程实践和方法中,大致可以提炼出五大步骤:需求、分析、设计、编码、测试。
而体系结构是软件的骨架,是最重要的基础。
体系结构是涉及到每一步骤中。
一般在获取需要的同时,就应该开始分析软件的体系结构。
体系结构现在一般是各个大的功能模块组合成,然后描述各个部分的关系。
我一般认为框架是体系结构中每个模块中更细小的结构。
如需要表示web技术,就会用到MVC框架,而web功能只是整个软件体系中的一个功能模块。
每个框架可以有许多个实例,如用java实现的MVC框架structs。
而在框架之下就是设计模式,设计模式一般是应用中框架之中的,也可以说是对框架的补充。
因为框架只是提供了一个环境,需要我们我里面填入更多的东西。
无论是否应用了设计模式,你都可以实现软件的功能,而正确应用了设计模式,是我们对前人软件的设计或实现方法的一种继承,从而让你的软件更软。
体系结构是可以从不同视角来进行分析的,所以软件体系结构的设计可以按照不同的视角来进行的。
按4+1views的论述,那是四种views:逻辑、开发、过程、物理和场景。
因此体系结构是逐渐细化的,你不可能开始就拿出一个完美的体系结构,而只能根据开发过程逐渐对体系结构进行细化。
打个比方:如果我们准备建一个房子,那房子如果按功能来分:墙壁、地板、照明等,它是按那种样式来组成的,房子是四方的还是圆形的等,这样就组成了房子的体系结构。
在体系结构之下,我们可以把框架应用在每个模块中,例如墙壁,我们准备应用什么框架。
墙壁可以包括:窗户、门等。
窗户和门的组成的就是一种框架。
而窗户是什么形状的或者是大还是小,是要为了实现屋内的亮度的,因此挑选什么样的窗户就是设计模式。
软件架构的种类
根据我们关注的角度不同,可以将架构分成三种:软件系统中元件之间的关系,比如用户界面,数据库,外部系统接口,商业逻辑元件,等等。
比如下面就是笔者亲身经历过的一个软件系统的逻辑架构图
图2、一个逻辑架构的例子
从上面这张图中可以看出,此系统被划分成三个逻辑层次,即表象层次,商业层次和数据持久层次。
每一个层次都含有多个逻辑元件。
比如WEB服务器层次中有HTML服务元件、Session服务元件、安全服务元件、系统管理元件等。
软件元件是怎样放到硬件上的。
比如下面这张物理架构图描述了一个分布于北京和上海的分布式系统的物理架构,图中所有的元件都是物理设备,包括网络分流器、代理服务器、WEB服务器、应用服务器、报表服务器、整合服务器、存储服务器、主机等等。
系统的非功能性特征,如可扩展性、可靠性、强壮性、灵活性、性能等。
系统架构的设计要求架构师具备软件和硬件的功能和性能的过硬知识,这一工作无疑是架构设计工作中最为困难的工作。
此外,从每一个角度上看,都可以看到架构的两要素:元件划分和设计决定。
首先,一个软件系统中的元件首先是逻辑元件。
这些逻辑元件如何放到硬件上,以及这些元件如何为整个系统的可扩展性、可靠性、强壮性、灵活性、性能等做出贡献,是非常重要的信息。
其次,进行软件设计需要做出的决定中,必然会包括逻辑结构、物理结构,以及它们如何影响到系统的所有非功能性特征。
这些决定中会有很多是一旦作出,就很难更改的。
根据作者的经验,一个基于数据库的系统架构,有多少个数据表,就会有多少页的架构设计文档。
比如一个中等的数据库应用系统通常含有一百个左右的数据表,这样的一个系统设计通常需要有一百页左右的架构设计文档。
图解几种常见的软件架构模式
本篇经验将和大家介绍几种常见的软件架构模式,希望对大家的工作和学习有所帮助!
方法/步骤
分层模式
这种模式也称为多层体系架构模式。
它可以用来构造可以分解为子任务组的程序,每个子任务都处于一个特定的抽象级别。
每个层都为下一个提供更高层次服务。
一般信息系统中最常见的是如下所列的4层。
表示层(也称为UI层)
应用层(也称为服务层)
业务逻辑层(也称为领域层)
数据访问层(也称为持久化层)
使用场景:
一般的桌面应用程序
电子商务Web应用程序
客户端-服务器模式
这种模式由两部分组成:一个服务器和多个客户端。
服务器组件将为多个客户端组件提供服务。
客户端从服务器请求服务,服务器为这些客户端提供相关服务。
此外,服务器持续侦听客户机请求。
使用场景:
电子邮件,文件共享和银行等在线应用程序
主从设备模式
这种模式由两方组成;主设备和从设备。
主设备组件在相同的从设备组件中分配工作,并计算最终结果,这些结果是由从设备返回的结果。
使用场景:
在计算机系统中与总线连接的外围设备(主和从驱动器)
管道-过滤器模式
此模式可用于构造生成和处理数据流的系统。
每个处理步骤都封装在一个过滤器组件内。
要处理的数据是通过管道传递的。
这些管道可以用于缓冲或用于同步。
使用场景:
编译器。连续的过滤器执行词法分析、解析、语义分析和代码生成
生物信息学的工作流
代理模式
此模式用于构造具有解耦组件的分布式系统。
这些组件可以通过远程服务调用彼此交互。
代理组件负责组件之间的通信协调。
服务器将其功能(服务和特征)发布给代理。
客户端从代理请求服务,然后代理将客户端重定向到其注册中心的适当服务。
使用场景:
消息代理软件,如ApacheActiveMQ,ApacheKafka,RabbitMQ和JBossMessaging
点对点模式
在这种模式中,单个组件被称为对等点。
对等点可以作为客户端,从其他对等点请求服务,作为服务器,为其他对等点提供服务。
对等点可以充当客户端或服务器或两者的角色,并且可以随时间动态地更改其角色。
使用场景:
像Gnutella和G2这样的文件共享网络
多媒体协议,如P2PTV和PDTP
像Spotify这样的专有多媒体应用程序
事件总线模式
这种模式主要是处理事件,包括4个主要组件:事件源、事件监听器、通道和事件总线。
消息源将消息发布到事件总线上的特定通道上。
侦听器订阅特定的通道。
侦听器会被通知消息,这些消息被发布到它们之前订阅的一个通道上。
使用场景:
安卓开发
通知服务
模型-视图-控制器模式
这种模式,也称为MVC模式,把一个交互式应用程序划分为3个部分,
模型:包含核心功能和数据
视图:将信息显示给用户(可以定义多个视图)
控制器:处理用户输入的信息
这样做是为了将信息的内部表示与信息的呈现方式分离开来,并接受用户的请求。
它分离了组件,并允许有效的代码重用。
使用场景:
在主要编程语言中互联网应用程序的体系架构
像Django和Rails这样的Web框架
黑板模式
这种模式对于没有确定解决方案策略的问题是有用的。
黑板模式由3个主要组成部分组成。
黑板——包含来自解决方案空间的对象的结构化全局内存
知识源——专门的模块和它们自己的表示
控制组件——选择、配置和执行模块
所有的组件都可以访问黑板。
组件可以生成添加到黑板上的新数据对象。
组件在黑板上查找特定类型的数据,并通过与现有知识源的模式匹配来查找这些数据。
使用场景:
语音识别
车辆识别和跟踪
蛋白质结构识别
声纳信号的解释
解释器模式
这个模式用于设计一个解释用专用语言编写的程序的组件。
它主要指定如何评估程序的行数,即以特定的语言编写的句子或表达式。
其基本思想是为每种语言的符号都有一个分类。
使用场景:
数据库查询语言,比如SQL
用于描述通信协议的语言
软件的系统架构和开发平台都有哪些?具体都有哪几种呢?
一、软件的系统架构
(一)、分层架构
分层架构(layeredarchitecture)是最常见的软件架构,也是事实上的标准架构。
如果你不知道要用什么架构,那就用它。
这种架构将软件分成若干个水平层,每一层都有清晰的角色和分工,不需要知道其他层的细节。
层与层之间通过接口通信。
虽然没有明确约定,软件一定要分成多少层,但是四层的结构最常见。
表现层(presentation):用户界面,负责视觉和用户互动
业务层(business):实现业务逻辑
持久层(persistence):提供数据,SQL语句就放在这一层
数据库(database):保存数据
有的软件在逻辑层和持久层之间,加了一个服务层(service),提供不同业务逻辑需要的一些通用接口。
用户的请求将依次通过这四层的处理,不能跳过其中任何一层。
(二)事件驱动架构
事件(event)是状态发生变化时,软件发出的通知。
事件驱动架构(event-drivenarchitecture)就是通过事件进行通信的软件架构。
它分成四个部分。
事件队列(eventqueue):接收事件的入口
分发器(eventmediator):将不同的事件分发到不同的业务逻辑单元
事件通道(eventchannel):分发器与处理器之间的联系渠道
事件处理器(eventprocessor):实现业务逻辑,处理完成后会发出事件,触发下一步操作
对于简单的项目,事件队列、分发器和事件通道,可以合为一体,整个软件就分成事件代理和事件处理器两部分。
(三)微核架构
微核架构(microkernelarchitecture)又称为插件架构(plug-inarchitecture),指的是软件的内核相对较小,主要功能和业务逻辑都通过插件实现。
内核(core)通常只包含系统运行的最小功能。
插件则是互相独立的,插件之间的通信,应该减少到最低,避免出现互相依赖的问题。
(四)、微服务架构
微服务架构(microservicesarchitecture)是服务导向架构(service-orientedarchitecture,缩写SOA)的升级。
每一个服务就是一个独立的部署单元(separatelydeployedunit)。
这些单元都是分布式的,互相解耦,通过远程通信协议(比如REST、SOAP)联系。
(五)、云架构
云结构(cloudarchitecture)主要解决扩展性和并发的问题,是最容易扩展的架构。
它的高扩展性,主要原因是没使用中央数据库,而是把数据都复制到内存中,变成可复制的内存数据单元。
然后,业务处理能力封装成一个个处理单元(prcessingunit)。
访问量增加,就新建处理单元;访问量减少,就关闭处理单元。
由于没有中央数据库,所以扩展性的最大瓶颈消失了。
由于每个处理单元的数据都在内存里,最好要进行数据持久化。
这个模式主要分成两部分:处理单元(processingunit)和虚拟中间件(virtualizedmiddleware)。
处理单元:实现业务逻辑
虚拟中间件:负责通信、保持sessions、数据复制、分布式处理、处理单元的部署。
二、开发平台
ERP平台、金融电商平台、小程序平台、网站平台、bpm平台、低代码开发平台等等;
厂家有天翎、顶点、天纵、清流、K2等
开发语言有区分:dephp、java。net等;
三、如何选择合适的开发平台?
平台的选型,无非是从客户业务需求的角度,以及对应的品牌形象和案例沉淀几个角度去选择;
建议可以开箱即用,多试用几次,就找到适合的产品,通俗的说,就是货比三家。
管理顾问,每天成长一点点,努力成就自己的优秀。
什么是SOA架构图?
SOA的核心主体是服务。
所谓“服务(Service)” ,从业务角度而言,服务是一个可重复的经过标准封装的任务,例如: 检查帐号余额;开新帐户 等等…。
SOA的目标是通过服务的流程化来实现业务的灵活性,所谓流程(Process)是由一系列相互关联的任务所组成,实现一个具体的业务功能。
一个流程可以由一系列服务来实现。
标准架构图如下:
一个正确的框架,是指导我们开发和实施SOA架构的基础。
由IBM提案,国际开放群组(The Open Group)提出了一个SOA架构的参考模型,这个架构框架目前是产业界最权威和严谨的SOA架构标准。
The Open Group是一个非营利标准化组织,是一个厂商中立和技术中立的机构,致力于提出各种技术框架和理论结构,致力于促进全球市场的业务效率。
The Open Group已有超过20年的标准制定与推广历史。
在1996年,由X/Open与Open Software Foundation合并组成。
The Open Group最有名是作为UNIX商标的认证机构。
在过去,协会最出名的是其出版的Single UNIX Specification,它扩充了POSIX标准而且是UNIX的官方定义,其成员包括IT用户、供应商以及政府机构。
The Open Group在中国的创始会员为金蝶集团,金蝶集团负责成立了中国分会。
TOG在1993年提出的The Open Group Architecture Framework (TOGAF) 架构框架,是一套行之有效的企业架构。
历经15年9个版本发展,支持开放、标准的SOA参考架构,已被80%的福布斯( Forbes)全球排名前50的公司使用。
根据这个模型,完整的SOA架构由五大部分组成,分别是:基础设施服务、企业服务总线、关键服务组件、开发工具、管理工具等。
SOA基础实施是为整个SOA组件和框架提供一个可靠的运行环境,以及服务组件容器,它的核心组件是应用服务器等基础软件支撑设施,提供运行期完整、可靠的软件支撑。
企业服务总线是指由中间件基础设施产品技术实现的、通过事件驱动和基于XML消息引擎,为SOA提供的软件架构的构造物。
企业服务总线ESB提供可靠消息传输、服务接入、协议转换、数据格式转换、基于内容的路由等功能,屏蔽了服务的物理位置,协议和数据格式。
在SOA基础实现的方案上,应用的业务功能能够被发布、封装和提升(Promote)成为业务服务(Business Service);业务服务的序列可以编排成为BPM的流程,而流程也可以被发布和提升为复合服务(Composited Service),业务服务还可以被外部的SOA系统再次编排和组合。
ESB是实现SOA治理的重要支撑平台,是SOA解决方案的核心,从某种意义上说,如果没有ESB,就不能算作严格意义上的SOA。
关键服务实现,是SOA在各种业务服务组件的分类。
一般来说,一个企业级的SOA架构通常包括:交互服务、流程服务、信息服务、伙伴服务、企业应用服务和接入服务。
这些服务可能是一些服务组件,也可能是企业应用系统(如ERP)所暴露的服务接口等等。
这些服务都可以接入ESB,进行集中统一管理。
开发工具和管理工具:提供完善的、可视化的服务开发和流程编排工具,涵盖服务的设计、开发、配置、部署、监控、重构等完整的SOA项目开发生命周期。
按照这个模型,许多SOA解决方案是只提供部分实现。
这个行业中,许多国内的企业为了搭上SOA的便车,经常以偏概全,混绕概念。
应该说真正按照SOA的思想和模型来构建整个企业的IT架构的案例是非常之少的。
许多国外厂商的宣传案例,基本上是停留在部署应用服务器,开发了部分WebService组件,可以实现部分数据集成,这个层次而已,而这些WebService是部署在ESB平台之上的,就已经很不错了。
实现了服务流程重组,实现SOA治理的案例就更是很少见到了。
OASIS(一个SOA标准组织)给予出的SOA定义“SOA是一个范式,用于组织和利用可能处于不同所有权范围控制下的分布式系统。”
维基百科给出的SOA定义“面向服务的体系结构(Service-oriented architecture)是构造分布式系统的应用程序的方法。
它将应用程序功能作为服务发送给最终用户或者其他服务。
它采用开放标准、与软件资源进行交互并采用表示的标准方式。
”。
要准确全面理解SOA,首先必须理解SOA的核心要素:
SOA的目标就是实现灵活可变的IT系统。
要达到灵活性,通过三个途径来解决:标准化封装、复用、松耦合可编排。
互操作(标准化封装)、复用、松耦合等SOA技术的内在机制,也是中间件技术和产品的本质特征。
标准化封装(互操作性)
传统软件架构,因为封装的技术和平台依赖性,一直没有彻底解决互操作问题。
互联网前所未有的开放性意味着各节点可能采用不同的组件、平台技术,对技术细节进行了私有化的约束,构件模型和架构没有统一标准,从而导致架构平台自身在组件描述、发布、发现、调用、互操作协议及数据传输等方面呈现出巨大的异构性。
各种不良技术约束的结果是软件系统跨互联网进行交互变得困难重重,最终导致了跨企业/部门的业务集成和重组难以灵活快速的进行。
在软件的互操作方面,传统中间件只是实现了访问互操作,即通过标准化的API实现了同类系统之间的调用互操作,而连接互操作还是依赖于特定的访问协议,如JAVA使用RMI,CORBA使用IIOP等。
而SOA通过标准的、支持Internet、与操作系统无关的SOAP协议实现了连接互操作。
而且,服务的封装是采用XML协议,具有自解析和自定义的特性,这样,基于SOA的中间件还可以实现语义互操作。
SOA要实现互操作,就是通过一系列的标准族,来实现访问、连接和语义等各种层面的互操作。
软件复用
软件复用,即软件的重用,也叫再用,是指同一事物不作修改或稍加改动就多次重复使用。
从软件复用技术的发展来看,就是不断提升抽象级别,扩大复用范围。
最早的复用技术是子程序,人们发明子程序,就可以在不同系统之间进行复用了。
但是,子程序是最原始的复用,因为这种复用范围是一个可执行程序内复用,静态开发期复用,如果子程序修改,意味着所有调用这个子程序的系统必须重新编译、测试和发布。
耦合关系
SOA架构在松耦合解耦过程也发展到了最后的境界。
传统软件将软件之中核心三部分网络连接、数据转换、业务逻辑全部耦合在一个整体之中,形成“铁板一块”的软件,“牵一发而动全身”,软件就难以适应变化。
分布式对象技术将连接逻辑进行分离,消息中间件将连接逻辑进行异步处理,增加了更大的灵活性。
消息代理和一些分布式对象中间件将数据转换也进行了分离。
而SOA架构,通过服务的封装,实现了业务逻辑与网络连接、数据转换等进行完全的解耦。
总之,从科学哲学的角度来看,SOA是一个不断解构的过程,传统软件强调系统性,耦合度过高,所以需要松耦合(解耦);SOA也是一个组件粒度的平衡,集成电路趋势是集成度越来越高,软件发展的趋势是相反的过程;SOA是架构,更是方法,反映了人们对哲学思想的追求的原动力。
按照这个特性,SOA基本上来说与WebService并不是同一个概念,SOA并不一定需要WebService实现,理论上可以在其他技术体系下,实现SOA。
但事实上,到目前为止,能够实现SOA架构风格的技术就是WebService,因为它的特性和厂商的支持力度,使得WebService成为了实现SOA实现技术的事实标准。
也正因为WebService技术的成熟,才使得已经提出10多年了的SOA思想和概念,得以能够实现落地,成为一种可以使用的技术。
这也就是回答了SOA和WebService的关系。
J2EE是什么东东?
J2EE Java2平台企业版(Java 2 Platform,Enterprise Edition) J2EE是一套全然不同于传统应用开发的技术架构,包含许多组件,主要可简化且规范应用系统的开发与部署,进而提高可移植性、安全与再用价值。
J2EE核心是一组技术规范与指南,其中所包含的各类组件、服务架构及技术层次,均有共通的标准及规格,让各种依循J2EE架构的不同平台之间,存在良好的兼容性,解决过去企业后端使用的信息产品彼此之间无法兼容,导致企业内部或外部难以互通的窘境。
在J2EE架构下,开发人员可依循规范基础,进而开发企业级应用;而不同J2EE供货商,同会支持不同J2EE版本内所拟定的标准,以确保不同J2EE平台与产品之间的兼容性。
换言之,植基J2EE架构的应用系统,基本上可部署在不同的应用服务器之上,无需或者只须要进行少量的代码修改,即能大幅提高应用系统的可移植性(Portability)。
J2EE主由升阳与IBM等厂商协同业界共同拟定而成的技术规范,以企业与企业之间的运算为导向的JAVA开发环境。
J2EE架构定义各类不同组件,如Web Component、EJB Component…等,而各类组件可以再用(reuse),让已开发完成的组件,或者是经由市面采购而得的组件,均能进一步组装成不同的系统。
对于开发人员而言,只需要专注于各种应用系统的商业逻辑与架构设计,至于底层繁琐的程序撰写工作,可搭配不同的开发平台,以让应用系统的开发与部署效率大幅提升。
J2EE的核心规范是 Enterprise Java Beans(EJBs)。
EJB依照特性的不同,目前共分为三种,分别是Session Bean、Entity Bean,以及 Message Driven Bean 。
其中 Session Bean 与Entity Bean 算是EJB的始祖,这两种EJB规格在EJB 1.x版本推出时就已经存在,而Message Driven Bean则是出现在EJB 2.0的规格之中。
目前业界许多程序设计师,或者是网页设计人员,多利用JSP/Servlet的便利性,进而在J2EE服务器之上开发相关的应用,或是整合公司内部的各种资源。
Java 2平台依照应用领域的不同,共分为三大版本,分别是J2EE、标准版本J2SE(Java 2 Platform, Standard Edition)、微型版本J2ME(Java 2 Platform, Micro Edition),以及Java Card等。
从整体上讲,J2EE是使用Java技术开发企业级应用的一种事实上的工业标准(Sun公司出于其自身利益的考虑,至今没有将Java及其相关技术纳入标准化组织的体系),它是Java技术不断适应和促进企业级应用过程中的产物。
Sun推出J2EE的目的是为了克服传统Client/Server模式的弊病,迎合Browser/Server架构的潮流,为应用Java技术开发服务器端应用提供一个平台独立的、可移植的、多用户的、安全的和基于标准的企业级平台,从而简化企业应用的开发、管理和部署。
J2EE是一个标准,而不是一个现成的产品。
各个平台开发商按照J2EE规范分别开发了不同的J2EE应用服务器,J2EE应用服务器是J2EE企业级应用的部署平台。
由于它们都遵循了J2EE规范,因此,使用J2EE技术开发的企业级应用可以部署在各种J2EE应用服务器上。
为了推广并规范化使用J2EE架构企业级应用的体系架构,Sun同时给出了一个建议性的J2EE应用设计模型:J2EE Blueprints。
J2EE Blueprints提供了实施J2EE企业级应用的体系架构、设计模式和相关的代码,通过应用J2EE Blueprints所描述的体系模型,能够部分简化架构企业级应用这项复杂的工作。
J2EE Blueprints是开发人员设计和优化J2EE组件的基本原则,同时为围绕开发工作进行职能分工给出了指导性策略,以帮助应用开发设计人员合理地分配技术资源。
J2EE组成了一个完整企业级应用的不同部分纳入不同的容器(Container),每个容器中都包含若干组件(这些组件是需要部署在相应容器中的),同时各种组件都能使用各种J2EE Service/API。
J2EE容器包括: ◆ Web容器 服务器端容器,包括两种组件JSP和Servlet,JSP和Servlet都是Web服务器的功能扩展,接受Web请求,返回动态的Web页面。
Web容器中的组件可使用EJB容器中的组件完成复杂的商务逻辑。
◆ EJB容器 服务器端容器,包含的组件为EJB(Enterprise JavaBeans),它是J2EE的核心之一,主要用于服务器端的商业逻辑的实现。
EJB规范定义了一个开发和部署分布式商业逻辑的框架,以简化企业级应用的开发,使其较容易地具备可伸缩性、可移植性、分布式事务处理、多用户和安全性等。
◆ Applet容器 客户端容器,包含的组件为Applet。
Applet是嵌在浏览器中的一种轻量级客户端,一般而言,仅当使用Web页面无法充分地表现数据或应用界面的时候,才使用它。
Applet是一种替代Web页面的手段,我们仅能够使用J2SE开发Applet,Applet无法使用J2EE的各种Service和API,这是为了安全性的考虑。
◆ Application Client容器 客户端容器,包含的组件为Application Client。
Application Client相对Applet而言是一种较重量级的客户端,它能够使用J2EE的大多数Service和API。
通过这四个容器,J2EE能够灵活地实现前面描述的企业级应用的架构。
在View部分,J2EE提供了三种手段:Web容器中的JSP(或Servlet)、Applet和Application Client,分别能够实现面向浏览器的数据表现和面向桌面应用的数据表现。
Web容器中的Servlet是实现Controller部分业务流程控制的主要手段;而EJB则主要针对Model部分的业务逻辑实现。
至于与各种企业资源和企业级应用相连接,则是依靠J2EE的各种服务和API。
在J2EE的各种服务和API中,JDBC和JCA用于企业资源(各种企业信息系统和数据库等)的连接,JAX-RPC、JAXR和SAAJ则是实现Web Services和Web Services连接的基本支持。
J2EE的各种组件 我们就J2EE的各种组件、服务和API,进行更加详细的阐述,看看在开发不同类型的企业级应用时,根据各自需求和目标的不同,应当如何灵活使用并组合不同的组件和服务。
· Servlet Servlet是Java平台上的CGI技术。
Servlet在服务器端运行,动态地生成Web页面。
与传统的CGI和许多其它类似CGI的技术相比,Java Servlet具有更高的效率并更容易使用。
对于Servlet,重复的请求不会导致同一程序的多次转载,它是依靠线程的方式来支持并发访问的。
· JSP JSP(Java Server Page)是一种实现普通静态HTML和动态页面输出混合编码的技术。
从这一点来看,非常类似Microsoft ASP、PHP等技术。
借助形式上的内容和外观表现的分离,Web页面制作的任务可以比较方便地划分给页面设计人员和程序员,并方便地通过JSP来合成。
在运行时态,JSP将会被首先转换成Servlet,并以Servlet的形态编译运行,因此它的效率和功能与Servlet相比没有差别,一样具有很高的效率。
· EJB EJB定义了一组可重用的组件:Enterprise Beans。
开发人员可以利用这些组件,像搭积木一样建立分布式应用。
在装配组件时,所有的Enterprise Beans都需要配置到EJB服务器(一般的Weblogic、WebSphere等J2EE应用服务器都是EJB服务器)中。
EJB服务器作为容器和低层平台的桥梁管理着EJB容器,并向该容器提供访问系统服务的能力。
所有的EJB实例都运行在EJB容器中。
EJB容器提供了系统级的服务,控制了EJB的生命周期。
EJB容器为它的开发人员代管了诸如安全性、远程连接、生命周期管理及事务管理等技术环节,简化了商业逻辑的开发。
EJB中定义了三种Enterprise Beans: ◆ Session Beans ◆ Entity Beans ◆ Message-driven Beans · JDBC JDBC(Java Database Connectivity,Java数据库连接)API是一个标准SQL(Structured Query Language,结构化查询语言)数据库访问接口,它使数据库开发人员能够用标准Java API编写数据库应用程序。
JDBC API主要用来连接数据库和直接调用SQL命令执行各种SQL语句。
利用JDBC API可以执行一般的SQL语句、动态SQL语句及带IN和OUT参数的存储过程。
Java中的JDBC相当与Microsoft平台中的ODBC(Open Database Connectivity)。
· JMS JMS(Java Message Service,Java消息服务)是一组Java应用接口,它提供创建、发送、接收、读取消息的服务。
JMS API定义了一组公共的应用程序接口和相应语法,使得Java应用能够和各种消息中间件进行通信,这些消息中间件包括IBM MQ-Series、Microsoft MSMQ及纯Java的SonicMQ。
通过使用JMS API,开发人员无需掌握不同消息产品的使用方法,也可以使用统一的JMS API来操纵各种消息中间件。
通过使用JMS,能够最大限度地提升消息应用的可移植性。
JMS既支持点对点的消息通信,也支持发布/订阅式的消息通信。
· JNDI 由于J2EE应用程序组件一般分布在不同的机器上,所以需要一种机制以便于组件客户使用者查找和引用组件及资源。
在J2EE体系中,使用JNDI(Java Naming and Directory Interface)定位各种对象,这些对象包括EJB、数据库驱动、JDBC数据源及消息连接等。
JNDI API为应用程序提供了一个统一的接口来完成标准的目录操作,如通过对象属性来查找和定位该对象。
由于JNDI是独立于目录协议的,应用还可以使用JNDI访问各种特定的目录服务,如LDAP、NDS和DNS等。
· JTA JTA(Java Transaction API)提供了J2EE中处理事务的标准接口,它支持事务的开始、回滚和提交。
同时在一般的J2EE平台上,总提供一个JTS(Java Transaction Service)作为标准的事务处理服务,开发人员可以使用JTA来使用JTS。
· JCA JCA(J2EE Connector Architecture)是J2EE体系架构的一部分,为开发人员提供了一套连接各种企业信息系统(EIS,包括ERP、SCM、CRM等)的体系架构,对于EIS开发商而言,它们只需要开发一套基于JCA的EIS连接适配器,开发人员就能够在任何的J2EE应用服务器中连接并使用它。
基于JCA的连接适配器的实现,需要涉及J2EE中的事务管理、安全管理及连接管理等服务组件。
· JMX JMX(Java Management Extensions)的前身是JMAPI。
JMX致力于解决分布式系统管理的问题。
JMX是一种应用编程接口、可扩展对象和方法的集合体,可以跨越各种异构操作系统平台、系统体系结构和网络传输协议,开发无缝集成的面向系统、网络和服务的管理应用。
JMX是一个完整的网络管理应用程序开发环境,它同时提供了厂商需要收集的完整的特性清单、可生成资源清单表格、图形化的用户接口;访问SNMP的网络API;主机间远程过程调用;数据库访问方法等。
· JAAS JAAS(Java Authentication and Authorization Service)实现了一个Java版本的标准Pluggable Authentication Module(PAM)的框架。
JAAS可用来进行用户身份的鉴定,从而能够可靠并安全地确定谁在执行Java代码。
同时JAAS还能通过对用户进行授权,实现基于用户的访问控制。
· JACC JACC(Java Authorization Service Provider Contract for Containers)在J2EE应用服务器和特定的授权认证服务器之间定义了一个连接的协约,以便将各种授权认证服务器插入到J2EE产品中去。
· JAX-RPC 通过使用JAX-RPC(Java API for XML-based RPC),已有的Java类或Java应用都能够被重新包装,并以Web Services的形式发布。
JAX-RPC提供了将RPC参数(in/out)编码和解码的API,使开发人员可以方便地使用SOAP消息来完成RPC调用。
同样,对于那些使用EJB(Enterprise JavaBeans)的商业应用而言,同样可以使用JAX-RPC来包装成Web服务,而这个Web Servoce的WSDL界面是与原先的EJB的方法是对应一致的。
JAX-RPC为用户包装了Web服务的部署和实现,对Web服务的开发人员而言,SOAP/WSDL变得透明,这有利于加速Web服务的开发周期。
· JAXR JAXR(Java API for XML Registries)提供了与多种类型注册服务进行交互的API。
JAXR运行客户端访问与JAXR规范相兼容的Web Servcices,这里的Web Services即为注册服务。
一般来说,注册服务总是以Web Services的形式运行的。
JAXR支持三种注册服务类型:JAXR Pluggable Provider、Registry-specific JAXR Provider、JAXR Bridge Provider(支持UDDI Registry和ebXML Registry/Repository等)。
· SAAJ SAAJ(SOAP with Attachemnts API for Java)是JAX-RPC的一个增强,为进行低层次的SOAP消息操纵提供了支持。
企业级应用示例 下面我们通过假设一个企业应用的J2EE实现,来了解各种组件和服务的应用。
假设应用对象是计算机产品的生产商/零售商的销售系统,这个销售系统能够通过自己的网站发布产品信息,同时也能将产品目录传送给计算机产品交易市场。
销售系统能够在线接受订单(来自自己的Web网站或者来自计算机产品交易市场),并随后转入内部企业管理系统进行相关的后续处理。
参见图3,这个企业应用可以这种方式架构。
该企业应用的核心是产品目录管理和产品定购管理这两个业务逻辑,使用EJB加以实现,并部署在EJB容器中。
由于产品目录和定购信息都需要持久化,因此使用JDBC连接数据库,并使用JTA来完成数据库存取事务。
图3 J2EE应用示例 然后使用JSP/Servlet来实现应用的Web表现:在线产品目录浏览和在线定购。
为了将产品目录发送给特定的交易市场,使用JMS实现异步的基于消息的产品目录传输。
为了使得更多的其它外部交易市场能够集成产品目录和定购业务,需要使用Web Services技术包装商业逻辑的实现。
由于产品定购管理需要由公司内部雇员进行处理,因此需要集成公司内部的用户系统和访问控制服务以方便雇员的使用,使用JACC集成内部的访问控制服务,使用JNDI集成内部的用户目录,并使用JAAS进行访问控制。
由于产品订购事务会触发后续的企业ERP系统的相关操作(包括仓储、财务、生产等),需要使用JCA连接企业ERP。
最后为了将这个应用纳入到企业整体的系统管理体系中去,使用Application Client架构了一个管理客户端(与其它企业应用管理应用部署在一台机器上),并通过JMX管理这个企业应用。















