基于 SOA 的组件化业务基础平台
业务基础平台是业务逻辑应用和基础架构平台之间的一个中间层,解决 “应用软件的业务描述和操作系统平台、软件基础架构平台之间的交互与管理问题”。操作系统平台解决了“应用软件系统与硬件之间的交互与管理问题”,软件基础架构平台解决了“应用软件系统与操作系统平台之间的交互与管理问题”,而业务基础平台则是解决了“应用软件的业务描述与操作系统平台、软件基础架构平台之间的交互与管理问题”。如下图所示:
图 1. 业务基础平台在技术架构中的位置
业务基础平台的组件化,并不是所有的内容全部组件化,有些内容是无法分离出去的,因此首先要把业务基础平台的内核分离出来,建立一个业务基础平台的微内核,微内核是跟每一个业务组件紧密相关的。然后把业务基础平台中可以分离出来的内容单独作为一个组件,即公共组件,从而实现业务组件和公共组件的分离。
1、业务基础平台主要业务组件
公共服务组件包含系统管理、流程管理、主数据管理、元数据管理等,在数据层面分别对应着系统数据、流程数据、主数据和元数据等数据。考虑到公共服务组件的独立性,特别是保证每一个组件独立升级之后不会影响到其他的公共服务组件以及业务组件,因此需要对公共服务组件进行隔离。
图 4. 业务基础平台主要业务组件
>系统管理主要包含:
用户管理、功能管理、权限管理、认证管理等功能,其中需要特别注意的是实现不同的业务组件的统一认证的问题,即实现不同的业务组件部署在不同的应用下(在 J2EE 环境下为 EAR 文件)的单点登录。
>主数据管理主要包含:
主数据模型管理、主数据质量控制、主数据监控等功能,主要实现各个组件之间公用的基础数据的管理,需要考虑主数据在那个业务组件中进行维护的问题,不同的主数据需要在不同的业务组件中完成,而不是所有的主数据都在主数据管理组件完成。
>流程管理主要包含:
代办任务管理、流程自定义、流程引擎等功能,主要实现对代办任务的统一管理、流程的管理。流程管理主要实现流程和业务的分离,并实现办公用的灵活流程、业务用的固定流程,详见《基于 SOA 的工作流(WF)整合》的描述。
>元数据的管理主要包含:
元数据管理、数据质量监控等功能,主要实现技术元数据和业务元数据的管理。
2、业务基础平台组件接口调用方式
不能仅仅是为了组件化而组件化,如果不能解决性能问题,组件化就不能在大型的应用系统中得到广泛应用,因此需要根据在实际开发过程中碰到的不同的场景,采用不同的调用方式,除了组件化中提到的服务,还有要有其他的方式作为补充,即能实现松耦合,又可以保证性能,实现不同层次的不同调用。
组件之间的调用关系主要有服务接口和数据接口两种。如下图所示:

图 5. 业务组件接口模型
在不同的层级,从性能和耦合性两个角度,组件间可以选择不同的调用方式, 具体采用那种调用关系主要是考虑性能、接口复杂度、耦合性等问题。

图 6. 组件化业务基础平台接口调用方式
- 基于 SOAP 的服务接口:通过 SOAP 的 Web 服务调用,适用于不同的业务组件之间,特别是不同厂商开发的业务组件、不同平台的业务组件以及新建的业务组件和遗留系统之间的调用。SOAP 的服务接口有相关的标准支持,可以支持更多的平台和厂商。
- 基于 REST 的服务接口:同平台、同厂商开发的业务组件之间的调用,特别是同一个组件中界面和业务逻辑之间的调用,从而实现界面和业务逻辑分离。REST 服务是轻量级的服务调用,主要用于提高性能,简化开发。
业务组件之间于 SOAP 的 Web 服务调用或者 REST Web 服务调用,因为基于 SOAP 的 Web 服务拥有众多的标准,可以方便的实现跨平台调用,适用于不同厂商之间的业务组件调用,同一个厂商之间的不同组件调用可以直接通过能够提供很好性能的 REST Web 服务调用。
- 基于 API 的调用 ,业务组件内部不同模块之间的;业务组件和基础平台的内核之间;业务组件和公共模块之间的调用;不同的业务组件之间需要紧密结合事务处理的调用,通过 API 调用实现,保证系统的事务处理和系统性能。
不同的业务组件之间需要事务处理的调用,通过内嵌一个内核业务处理模块的方式进行,如库存处理相关业务,在订单模块和采购模块都需要调用,通过服务方式很难处理事物,可以将一个简化的库存模块(如 Jar 包,建议采用 OSGi 架构,WAS8 已经提供了很好的支持)直接内嵌到订单模块和采购模块,如下图“库存模块内嵌到订单和采购业务组件”所示;工作流引擎也可以采用这样的方式,详见《基于 SOA 的工作流(WF)整合》的说明。

图 7. 库存模块内嵌到订单和采购业务组件
- 基于数据接口调用:同平台、同厂商开发的业务组件,可以直接通过数据视图调用,简化接口关系,特别开发比较紧密的小组开发的组件之间调用、大数据量的数据调用。不同的业务组件之间,纯粹的数据调用,可以直接通过数据接口方式进行调用.
界面组件和业务逻辑组件应该是可以完全独立的,在完全实现组件化业务基础平台中,界面组件应该是可以独立部署的,界面组件和业务逻辑组件之间通过 REST 的服务交互,详见《 SOA 和 ROA 》所描述的架构说明。业务逻辑组件可以没有任何界面,完全独立于界面显示,实现界面和业务的分离。在 J2EE 环境中,完全可以实现业务组件全部由 Jar 包组成,不含任何界面内容,界面组件则完全采用 JSP 实现。
基于数据接口调详见《 SOA 和 DW 》关于共享库的描述,在实现所有的组件公用一个数据库的基础上,不同业务组件需要确定数据接口作为共享标准(如下图所示深蓝色部分流程、系统、主数据、业务一、业务二、···),其中有些数据是不需要在不同的业务组件进行共享的,则属于组件内部的数据,(如下图所示淡蓝色部分流程、系统、主数据、业务一、业务二、···),对于业务基础平台所包含的业务组件流程、系统、主数据也采用这样的方式,可以保证业务基础平台向下兼容的进行独立升级,而不会影响到其他的业务组件。

图 8. 数据接口实现思路
总结
相比传统的业务基础平台,组件化业务基础平台能够实现业务基础平台组件之间以及业务组件之间的松耦合,可以实现:
- 因为业务基础平台内核分离出来,业务基础平台可以独立升级,不会影响到业务组件运行和开发,这样保证了资产的复用,不至于业务基础平台升级后,业务组件也必须跟着升级,减少不必要的重复开发。
- 每个业务组件可以独立升级,不会影响其他的业务组件,基于松耦合的组件化开发,不同的业务组件之间通过标准的接口调用,接口是标准的,不需要对所有的业务组件进行升级。
- 业务基础平台可以独立部署,独立部署之后,可以整合其他厂商基于开放标准开发的业务组件,从而实现企业级的集成平台(需要数据集成和应用集成平台支持)。
基于 SOA 的组件化业务基础平台的更多相关文章
- 基于SOA的组件化业务基础平台[转]
转自https://www.ibm.com/developerworks/cn/webservices/1111_xiaojg_soa/index.html 业务基础平台是业务逻辑和基础架构平台之间的 ...
- 面向服务体系架构(SOA)和数据仓库(DW)的思考基于 IBM 产品体系搭建基于 SOA 和 DW 的企业基础架构平台
面向服务体系架构(SOA)和数据仓库(DW)的思考 基于 IBM 产品体系搭建基于 SOA 和 DW 的企业基础架构平台 当前业界对面向服务体系架构(SOA)和数据仓库(Data Warehouse, ...
- 企业 SOA 设计(2)–组件化产品开发平台
上一篇<企业 SOA 设计(1)–ESB 设计>中,写到我们的 SOA 设计分为两个层面来进行:一个是系统间的 SOA 设计,主要通过 ESB 来完成:另一方面则是单个应用系统内部的 SO ...
- Spting:基于注解的组件化管理
@Component,@Controller(控制层),@Service(业务层),@Repository(持久层) 以上四个注解的功能完全相同,不过在实际开发中,要在不同功能的类上加上响应的注解 1 ...
- 基于surging网络组件多协议适配的平台化发展
前言 Surging 发展已经有快6年的时间,经过这些年的发展,功能框架也趋于成熟,但是针对于商业化需求还需要不断的打磨,前段时间客户找到我想升级成平台化,针对他的需求我 ...
- 教你打造一个Android组件化开发框架
*本篇文章已授权微信公众号 guolin_blog (郭霖)独家发布 CC:Component Caller,一个android组件化开发框架, 已开源,github地址:https://github ...
- 【转】谈基于SOA的应用系统设计和开发
注:在网上看到这篇文档,觉得写得很好,清晰实用.该博客其它文章也写得不错 地址:http://blog.sina.com.cn/s/blog_493a84550101gswn.html 现在对 ...
- 得到、微信、美团、爱奇艺APP组件化架构实践
一.背景 随着项目逐渐扩展,业务功能越来越多,代码量越来越多,开发人员数量也越来越多.此过程中,你是否有过以下烦恼? 项目模块多且复杂,编译一次要5分钟甚至10分钟?太慢不能忍? 改了一行代码 或只调 ...
- iOS 组件化 —— 路由设计思路分析
原文 前言 随着用户的需求越来越多,对App的用户体验也变的要求越来越高.为了更好的应对各种需求,开发人员从软件工程的角度,将App架构由原来简单的MVC变成MVVM,VIPER等复杂架构.更换适合业 ...
随机推荐
- ado通用操作数据单元
DELPHI开发2层C/S数据库应用程序,许多人通过ADOQUERY或ADOTABLE直接操作数据库,其实这种方法虽然最为直接,但有其缺点:如果以后要将程序升级为3层C/S会非常困难.而通过像下面的通 ...
- Qt实现应用程序单实例运行--LocalServer方式
使Qt应用程序能够单实例运行的典型实现方法是使用共享内存实现.该方法实现简单,代码简洁. 但有一个致命缺陷:共享内存(QSharedMemory)实现的单程序运行,当运行环境是UNIX时,并且程序不幸 ...
- HDU3874Necklace(树状数组+离线操作)
此题的大意思说有一串珠子,每个珠子都有自己的欣赏值value,现在给你一串珠子每个的欣赏值,并给出一些询问,查询某个区间内部总欣赏值是多少,但是有一个约定就是如果这个区间内部有两个珠子的欣赏值是一样的 ...
- URAL 2069 Hard Rock (最短路)
题意:给定 n + m 个街道,问你从左上角走到右下角的所有路的权值最小的中的最大的. 析:我们只要考虑几种情况就好了,先走行再走列和先走列再走行差不多.要么是先横着,再竖着,要么是先横再竖再横,要么 ...
- oracle创建自增长列
--创建一个新表 /*create table students(stu_id number,stu_name varchar2(20),stu_email varchar2(40),primary ...
- 无责任Windows Azure SDK .NET开发入门篇三[使用Azure AD 管理用户信息--3.3 Details用户详细信息]
3.3 Details用户详细信息 用户详细信息是通过objectId获取.代码如下 public async Task<ActionResult> Details(string obje ...
- winrar激活
(从已经死了一次又一次终于挂掉的百度空间人工抢救出来的,发表日期2014-02-11) 新建记事本文件(txt文件),然后将文件另存为以 rarreg.key 为文件名的文件(当然由于设置的不同,可能 ...
- ATSHA204加密认证IC
The Atmel® ATSHA204 is a full turnkey security device. It includes a 4.5Kb EEPROM divided into 16 sl ...
- CUDA Memories--CUDA记忆体(翻译+整理+测试)
一边学习一边记录(本文中英结合,专业名词统统不翻译) 在CUDA里,host和devices有不同的记忆体空间. 首先呢,CUDA的memory有很多种类啦 1. Global memory 2. C ...
- C++ Primer 学习笔记_46_STL实践与分析(20)--容器特有的算法
STL实践与分析 --容器特有的算法 与其它顺序容器所支持的操作相比,标准库为list容器定义了更精细的操作集合,使它不必仅仅依赖于泛型操作.当中非常大的一个原因就是list容器不是依照内存中的顺序进 ...