We use cookies and other similar technologies (Cookies) to enhance your experience and to provide you with relevant content and ads. By using our website, you are agreeing to the use of Cookies. You can change your settings at any time. Cookie Policy.

Pragmatic Software Design

Vijay Narayanan

Loosen Up Legacy System Interactions

user-pic
Vote 0 Votes

The hard thing about transforming legacy systems - tight coupling. When legacy systems interact with one another bi-directionally, and are intimately aware of each other's implementation approaches it becomes extremely difficult to work with. Legacy systems also have all kinds of logic in them - mixture of presentation, business rules, process orchestration, data access etc. Not to mention the increased cost of ownership and lack of transparency.

The first step towards transforming your legacy systems then is to loosen the tight coupling. Specifically:

  • Minimize (and eventually eliminate) point to point integrations between legacy systems
  • Migrate process orchestration and reengineer them using a business process layer. Orchestrations of calls across systems can be controlled from a separate layer rather than be done from every system
  • Use reliable messaging to exchange data between legacy systems and systems of record. Rather than including legacy systems in every orchestration you can keep data synchronized using an asynchronous flow.
  • Integrate legacy system operations with BPM layer so you can reuse standardized process flows. This is relevant when not all functions have migrated out of your legacy world and you need to reuse part of what you have built in your target platform
  • Iteratively transform functions from the legacy system - if you see a function that is needed for multiple use cases you can partially or completely move it out. Or wrap capabilities as services accessed through a mediation layer

Vijay Narayanan blogs about software design from several perspectives - SOA,BPM, messaging, systematic reuse, agility, and architecture.

Vijay Narayanan

Vijay Narayanan is a software professional working on a variety of projects. Vijay has worked on several software initiatives ranging from single-user systems to large, distributed, multi-user service platforms with services. Most recently, Vijay has been involved in research dedicated to combining agile practices with service-orientation. He is a contributing author to the upcoming book Next Generation SOA as part of a chapter on modern SOA methodologies. Vijay maintains a blog dedicated to software reuse at http://www.artofsoftwarereuse.com.

Recently Commented On

Monthly Archives

Blogs

ADVERTISEMENT