Skip to main content

JBoss Fuse integration service - Enhancing Customer Experience Through Integration and Automation of Business Events in the Cloud

This year in Red Hat summit, I have to honor to work with two intelligent colleague of mine Eric Schabell and Siamak Sadeghianfar to share an interesting workshop. The main theme on the workshop is demonstrate how rules automation can be implemented on the cloud and how to take advantage of the integration service to expose API and scalable across the network.

Red Hat OpenShift, is a Platform-as-a-Service (PaaS) that allows developers to quickly develop, host, and scale applications in a cloud environment.  The lab goes through basics concept of OpenShift, explaining the following terminology in OpenShift.

Container: Lightweight mechanisms for isolating running processes
Image: A binary that includes all of the requirements for running a single container, as well as metadata describing its needs and capabilities.
Pod: A small group of tightly coupled Containers sharing network, storage, etc
Service: A set of replicated pods that work together
Build: Process of transforming a set of parameters and source code into a runnable image
Route: A route is a way to expose a service by giving it an externally-reachable hostname like www.example.com
Template: Describes a set of objects that can be parameterized and processed to produce a list of objects for creation by OpenShift

As always, I want to focus more on the software development side, lets take a look at what is going on in the lab. The background of the scenario is a weight watcher program, which allows users to register with their weight loss target. Once registered, it will base on daily input from devices sent in to the system to provide calculated statistic of how this person is doing. 

Red Hat  JBoss BRMS, using the declarative logic with business rules to build applications with independent modularized rulesets. In our lab, we will deploy the business rule to a separate decision server. Here we use it store all the calculation logic of how your weight has progressed and to diagnose how the person is doing. A decision server will be deployed on the cloud and a project of set of rules will be applied to the server. Once the rules are loaded the server become our rule engine and ready to take in user data via web service. 

Having all the rules set up and start watching the weight providing advices is good. But we are now in the era of APIs, we want to maximize the use of the rules, creating a simple RESTFul API, it offers benefits such as additional decoupling, and allows extreme scalability. Since REST forbids conversational state, we can scale very wide by utilizing load balancer later on provided automatically by OpenShift. Other advantage such as uniform interface with Basic API operations makes other parties easy to follow. Red Hat JBoss Fuse is the perfect medium to turn the Business Rules into simple services API, it’s built-in interface. As it's REST DSL allows user to expose web API in simple context as well as have 150+ variety supported component to connect other service available. 


This example expose two RESTFul Endpoints, one takes in participants data and one receives constant updates of weight and returns the analyzed result back. There are few things we need to do 
  • Create an event base system by exposing RESTFul Endpoint using REST DSL with Camel 
  • Transform the entered data into JSON format required by BRMS, and then wrap these data in XML which is needed by decision server. 
  • Connecting to BRMS decision server with API Call 
  • Filter and parse the return result 
I have created demo that will automatically setup both BRMS and Fuse on OpenShift, 

       https://github.com/jbossdemocentral/jboss-fis-weightwatcher

The install and running instruction are as follows, 

Installation

Make sure you have installed Vagrant and Virtual box. run initCDK.sh to setup CDK and web services (SKIP this section if you have already installed)
$ ./initCDK.sh
Install the project on OpenShift by running init.sh
$ ./init.sh
Login to OpenShift console with USERNAME/PWD admin/admin
https://10.1.2.2:8443/console/                                    
Overview BrokerOverview TCP BrokerOverview FUSE BRMS
Also Pods, services and route
Overview BrokerOverview TCP BrokerOverview FUSE BRMS

Running the demo

Registering a new Participants: Before we start sending in weight, we need to register the participants and set their goal.
http://weightwatcherapi-fisdemo.rhel-cdk.10.1.2.2.xip.io/weightwatcher/addParticipant/2/ipavlov@behaviorist.org/75/84/70/78
Add Participant
Events - Updating weight: In a browser or any REST client app, trigger the event by updating the weight as we measure every-time. Each event will then pass into rule engine through our API. You should be able to see the calculated response from weight watcher.
http://weightwatcherapi-fisdemo.rhel-cdk.10.1.2.2.xip.io/weightwatcher/updateweight/2/2015-04-20%2007:15:00%20EST/79

http://weightwatcherapi-fisdemo.rhel-cdk.10.1.2.2.xip.io/weightwatcher/updateweight/2/2015-04-25%2007:15:00%20EST/77

http://weightwatcherapi-fisdemo.rhel-cdk.10.1.2.2.xip.io/weightwatcher/updateweight/2/2015-04-28%2007:15:00%20EST/76
Update weightCamel status




Comments

George Varghese said…
Can BRMS rules be applied on persisted data which is received at different points of time. The rule can run over the entire set of data that has been received for a patient over a period of time and that data set will only increase during the course of patient stay.

About the the rule itself, some of the clinical decision support rule needs to run every 5 minutes, some 15 minutes etc.

Monitoring Sepsis condition is a big requirement in USA, also have other scenarios where this will be very useful.

Thanks
Varsha aravind said…

What an awesome post, I just read it from start to end. Learned something new after a long time.


Car Cleaning Services in Mumbai


back to original car services
Cinderella K said…
This is a gorgeous place. The reception area and the waiting room of meeting space San Francisco will make you feel special. There is luxury vibes that will welcome you. Aside from this, the conference room contains many technology and catering options.
Shalini said…
I just see the post i am so happy to the communication science post of information's.So I have really enjoyed and reading your blogs for these posts.Any way I’ll be replay for your great thinks and I hope you post again soon.

digital marketing company in india

Popular posts from this blog

Fuse Integration Service - Setup JBDS and create first quickstart application

Before we go and start creating our first application, I want to show you how to setup your JBoss Developer Studio, create a small application from the quickstart example and then running it on Fuse Integration Service.

I am using JBoss Developer Studio version 9, you can find it here.
After download the

jboss-devstudio-9.0.0.GA-installer-eap.jar
double-click it, and start installing with default values.

After successful installation, we will need install the plugins for Fuse, on JBoss Central view, select software update, select enable early access.


And select JBoss Fuse Development for the plugin,


Click on install, and we are all set to go!

First thing first, we want to create a Fuse project to deploy on the base of Fuse Integration Service, which is OpenShift. If you have not installed it, please go back to my previous post for instructions. So on your JBDS, right click and start creating the project. Select new, maven project, if you have installed the plugin correctly, you should …

RHTE - Supercharge your integration services

Red Hat Tech Exchange has taken place in Vietnam, Ho Chi Minh city two weeks ago, it is a great event held by Red Hat in Asia Pacific Region. It is open to all Red Hat partners who are interested in learning what Red Hat is doing recently, see what the trend of the open source world, basically it is a great event to share your knowledge and experience, to meet other enthusiastic people.

I am very fortunate to talk in this great event, to talk about the things I have been working on and even discuss it with many. Also got lots of great ideas too. So here are the slide.

My first talk was with Thomas Qvarnström about how to handle large size data in JBoss Fuse and how JBoss Data Grid can help in the situation.

Here is the agenda of the talk, we will be talk about this in the up coming webinar on 24th Sept.

Integration often involves storing, retrieving, and transforming data. Using a traditional database in your integration is likely to becomes a bottleneck that is expensive and hard to …

Red Hat JBoss Fuse/A-MQ - Fuse and A-MQ Version 6.3 GA is released!

Fuse and A-MQ 6.3 GA has just went out. Maybe, you would think this is just only a minor version release why should I care? Hold your thoughts on that! Because they have done a lot of improvements and also added many new features into this release.

Besides various bug fixes and making sure Fuse Fabric is much more stable. There are two major change in this version update:

New Tooling in JBoss Developer Studio (JBDS) 9.1 GA. Newer Apache Camel version – Camel v2.17. I was really impressed by the work put in to make developing Camel application much simpler. First is the installation of tooling itself. Now it has a all-in-one installer so you don't need to worry about which plugins you need to check. See the videos below to see the new "Getting Started" of Fuse 6.3.



And If you notice from the above video, the presentation of camel route in JBDS has also updated. It fixed some of the miss representation of logic and making it easier to read.

Old Camel Route
New Camel Route
On …