实战:基于ESB的企业系统集成.docx

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实战:基于ESB的企业系统集成课案

实战:基于ESB的企业系统集成随着企业信息化程度的不断提高,越来越多的信息系统逐渐上线,这些系统在为企业带来效益的同时,也带来了一些让开发及维护人员头痛不已的问题,主要表现在系统分散,信息孤岛,交互复杂,维护成本太高。多说无益,直接上干货,请看下图:假设现在有A、B、C、D、E、F、G 7个业务系统。各系统均为独立的业务系统,系统的开发语言、所使用的数据库、所需要的运行环境也不尽相同。有些为自主开发,有些为外部采购。根据业务需求各系统间需要有各式的数据交互。为了更加直观,现将其假设为华信内部常用的系统名称。(实际上公司内部的系统要远远多于上述内容,并且关系更为复杂)。举例来说:假设A系统为HR系统,系统B为PMS系统、G为一卡通相关系统等等。为了与其他系统交互,各系统均提供webservice接口,用来接收处理数据。每个系统在发送数据时需要调用其他系统的接口,以HR系统为例:当有新员工入职时,首先将员工信息录入到本地系统中,然后分别通知,PMS、内网、DPark、联系人、门闸、消费等等系统,要求对方也同时追加该员工的相关信息,并根据需要向其他系统返回相应信息。于是一张密密麻麻的蜘蛛网就成型了。直观一点,我们看一下现在HR系统需要调用的接口:编号目标系统数据方向接口内容1PMS输出人员基本信息、人员职位、人员组织。。。2内网输出人员基本信息、人员职位、人员组织。。。3Dpark输出人员基本信息、人员职位、人员组织。。。4联系人输出人员基本信息、人员职位、人员组织。。。5邮箱输出人员基本信息、人员职位、人员组织。。。6门闸、门禁输出人员基本信息、人员职位、人员组织。。。7消费输出人员基本信息、人员职位、人员组织。。。既然有输出,就一定还会有输入,这里就不再列举。每个系统都会提供很多的接口,可以想象,现在的数据交互这部分的复杂程度和代码量。对编码人员和业务人员这都是一个很残酷的考验。每次新增一个系统或者改动某些现有业务就是一次噩梦。现在我们需要改变,我们目标是:以面向服务的方式,实现异构、分布式应用系统之间松散耦合的集成共享、互联互通的消息传送平台直观些,我们想要这样的东西:值得庆幸的是,之前的结构看起来虽然很乱,但是他们是基于SOA的。现在重新梳理一下我们面对的问题和需求:多对多的数据交换,牵一发动全身各业务系统的接口对外公开,安全性差业务逻辑多处重复,浪费开发资源难以进行的业务修改,无法快速推出新业务开发质量难以控制业务系统工作量很大简单说:我是一个业务系统,我不想同时和那么多业务系统打交道,多了我会晕的,我只想跟一个系统有交互。举个贴近生活的例子:我是名普通员工,我今天刷卡不好用了,你不能让我分别去跟Dpark、Pms、门禁、车场、消费等等那些相关人员去打交道,我只想跟一个人说一遍,然后等候结果就行了。这个中间的消息平台应该是什么呢?没错,就是她ESB。ESB的特点面向服务的架构 - 分布式的应用由可重用的服务组成;面向消息的架构 - 应用之间通过ESB发送和接受消息;事件驱动的架构 - 应用之间异步地产生和接收消息;ESB就是在SOA架构中实现服务间智能化集成与管理的中介。这简直就是为了解决我的问题而生的东西。现在看一看我们都需要做什么:接收数据:接收各系统发送过来的数据,这里采用对外发布webservice的方式。处理数据:对接收的数据进行相应的转换处理,以匹配不同的目标系统。举例:A系统中的性别字段中存储的是0,1 而B系统中是男,女。发送数据:根据业务规则将其发送给相关系统,调用对方提供的服务。现在看起来好多了。现在各业务系统只需要对外公开数据接收的服务就可以了。并且只需要调用ESB提供的一套webservice就可以,不用依次去调用每个系统的webservice。工作量大幅减少。为了让ESB知道我的数据要发送给那个系统,在ESB接收端有一个标识TargetSystem用以标识目标系统。好了,大家都很开心,但是,这样做真的已经很好了吗?我们通过对比来看一下。改造前改造后发送数据调用各系统提供的接口。只调用ESB提供的接口。接收数据由自身提供由自身提供数据处理业务系统自己处理ESB统一处理目标系统按需直接调用对方接口只需通知ESB系统压力被调用时产生压力ESB接收端压力巨大日志及错误各系统自行处理ESB处理安全性各系统间接口公开接口仅对ESB公开来一个实际的例子:公司组织机构调整,此次涉及1000人,这些人不光人员组织信息变动,还有职位信息变动,还有部分人的基本信息进行了变动(比如更换了手机号,增加了学历信息),此次信息修改的发起者是HR系统,方式是在零时统一执行,接收方有10个系统。那么未改造前HR会调用接口:1000人*3处变动*10个系统=30000次。改造后HR会调用接口:1000人*3处变动*1个系统=3000

文档评论(0)

jiayou10 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8133070117000003

1亿VIP精品文档

相关文档