Software Development

Integration platform as a service, the cloud, and… baby unicorns

cloud
Ahh yes, this mythical utopian “cloud” where unicorns frolic, butterflies abound, and magical elves fetch me a beer three quarters of a way into my current one.

I love that place.

 
 
I just saw this warm and fuzzy line on the website of an open-source wolf in sheep’s clothing company: “you can integrate any app, any data source and any device using a graphical interface” obviating any custom coding.

Well, maybe the unicorns code it for you.

For those of us in the real world that have worked on real, non-trivial, business-critical integration projects, we know the cold reality. They suck. Coding them by hand is going to land us into a world of hurt. So if we’re smart, we leverage existing tried-and-true integration libraries like Apache Camel to do the heavy lifting. If we want to keep the deployment simple, maybe we use our existing infrastructure like Apache Tomcat. If we want to get modular, have requirements for dynamic services and components, and want app configuration handled for us, maybe we choose Apache Karaf. And of course we test via unit tests, integration tests, system tests, etc, etc.

If you’re a developer you know the truth. If you’re a pointed-headed architect far removed from coding, you eat up the magic hand over fist.

There’s an awful lot of of hype around the “cloud”, but often times behind the smoke and mirrors there is some truth (or at least semblance of truth!). SOA, ESB, etc, all had they’re day on the hype curve but yet there was some substance to it once all the marketing cycles jumped onto the next bandwagon. The truth distilled you ask? I think the reality of “cloud” is highly virtualized environments (compute, storage, network), simplified deployments for your code, and allowing applications to scale elastically with some good legwork by you up front. But none of this happens by magic, you give up some things: to wit…. control. But in some cases the benefits might be worth it.

When I first saw the term “iPaaS”, I thought it was cute. “Integration Platform as a Service”. Someone is laughing all the way to the bank?

Until it hit me. We’re trying to make it easier to integrate systems right? It’ll never be drag and drop batta-boom-batta-bing (though you’ll pay millions thinking we can do it now), but there are definitely pain points that can be alleviated. Enterprise Integration Patterns? Automated tests? Continuous test/deployments, etc,etc… we’ve slowly, through all the barking and shilling, truly found ways to alleviate some of the pain points. But what about managing deployments and making it easier to “just deploy our code”?

We’ve honestly got great ways to virtualize the infrastructure that hosts our integration solutions and software, but if you’ve been on the build and release part of a process, you know what a shit show it can be.

Well, enter this idea of platform as a service.

Notice I didn’t capitalize the word “platform” or “service”…

A platform as a service, designed to help developers and devops make it easier to deploy code with little need for intimate knowledge of downloading, installing, configuring a system or container… and repeating it for scale and elasticity… mmmm.. what would that look like?

The answer, my friends: Fabric8.io / JBoss Fuse

Simply put, Fabric8/JBoss Fuse manages the containers and deployments for you. You just deploy your code. That is what a platform as a service is.

You can use Fuse in stand-alone development, in traditional static network environments, in private clouds, hybrid clouds, public clouds….

And as luck would have it,  this Fuse technology is available on one of those PaaS thingys..

Enough rambling, right Posta? Get to something worthwhile. So in the next part, I’ll show how to get started building a real Integration platform on a cloud PaaS with JBoss Fuse.

Christian Posta

Christian is a Principal Consultant at FuseSource specializing in developing enterprise software applications with an emphasis on software integration and messaging. His strengths include helping clients build software using industry best practices, Test Driven Design, ActiveMQ, Apache Camel, ServiceMix, Spring Framework, and most importantly, modeling complex domains so that they can be realized in software. He works primarily using Java and its many frameworks, but his favorite programming language is Python. He's in the midst of learning Scala and hopes to contribute to the Apache Apollo project.
Subscribe
Notify of
guest

This site uses Akismet to reduce spam. Learn how your comment data is processed.

0 Comments
Inline Feedbacks
View all comments
Back to top button