基于插件的服务集成方式
JamesGore119@gmail.com
企业信息系统集成是一个很大的主题,常见的集成手段有基于ESB、消息总线等。本文所提到的基于插件的服务集成方式,与信息系统集成没有太多的关联,主要是指系统内,多组件架构集成的一种方式。
在一个企业应用系统中,很少有一个组件或一个工程去满足所有的需求(除非系统很小),一般会纵向分层,横向分包,根据不同的问题领域折分成不同的组件。如一个典型的企业系统有认证、授权、审计、导航等,每个组件专注于所属问题领域,并对外提供服务。基于SOA的架构,这种方式更流行。每个服务组件对外提供服务,客户端(这里指调用程序)依赖于接口服务,不依赖于服务实现。服务实现可以在集成时进行指定,也就是部署或运行时,绑定服务接口及其实现,而非编译时连接。
这种方式带来的好处:
1. 减耦,封装变化
将实现与接口隔离,不仅从设计上分离,更从物理上分离,接口与实现分别在不同的包中。使得客户端依赖服务接口包,只关注接口提供的服务,服务实现在满足接口语义的前提下,任务变化都与客户端隔离。
2. 可插拨,可替换
服务实现依赖服务接口,但服务接口不依赖服务实现,客户端依赖于服务接口,这样通过插件机制,可在不同的环境使用不同的实现。如依据服务组件与调用程序是否部署在同一进程中,客户端调用的服务实现就可能不一样。
3. 利于团队协作与开发、测试
客户程序与服务组件可能是不同的