Enterprise Integration Patterns. Although some patterns are overly complex most of them are fundamental to any integration solution.
The three lightweight ESBs mentioned before are more or less strict implementations of EIP. More or less because not all patterns are supported. Note that to fill the gaps some higher level patterns can be home made from lower level patterns at the cost of ... development.
As underlined MOM are very poor concerning routing and transformation capabilities. Traditional ESBs require explicit configuration at various layers. This is where lightweight ESBs take place: bringing simplicity and efficiency by configuring only the required messaging patterns. Whether based on a Spring-XML or on a DSL configuration, lightweight ESBs rely on convention over configuration: for example an implicit protocol translator, an implicit router that does nothing special, etc.
You may often ear "no business in the integration middleware". When it comes to data translation most organizations have well-defined rules on what to put in the integration middleware and what not. The only rule is that there are no rules! It depends on too many factors to be cast in stone and the point should be addressed systematically.
Lightweight ESBs have the same mapping capabilities as traditional ones. Therefore same issues apply: whether to put the mapping logic on applications side or on the middleware side, whether to use Canonical Data Model or not, etc.
The term orchestration actually regroups two notions:
Lightweight ESBs address technical orchestrations very well. However, only simple business orchestrations are supported as they do not provide any advanced mechanism for message correlation, hibernation, compensation nor business activity monitoring.
Orchestration is one of the most influential criteria when comparing lightweight with traditional ESBs. Once again it depends on the business value to put in the middleware layer.
The lack of a business rules engine embedded in the integration solution is not penalizing as it intends to address different scenarios. Business rules engines schould be placed closer to the business logic with the most value, that means into applications.
Some integration stacks include a Complex Event Processing (CEP) engine too. However, CEP addresses different integration scenarios. The precious time saved by the fast patterns detection (events recognition) of CEP would be nibbled by the complex events collection and notification through the various integration layers. CEP solutions provide their own API for message input and offer other forms of Message Router. That is why CEP do not require to be coupled to an ESB.
Finally, lightweight ESBs do not offer business monitoring across multiple instances of a same flow definition. At most, what can be done is defining basic SLA such as timeout and overload protection. This is consistent with the type of orchestrations addressed.
Although lightweight ESBs support the detection of errors (Dead Letter Channel) and anomalies (Invalid Message Channel), they do not offer any framework for resubmitting messages. This implies either resubmitting the message from the source system or performing a corrective action on the target system.
That is mainly due to the fact that there is no native Message Store on the way. This is where lightweight ESBs still have gaps to fill. An alternative is to tool up with a custom error management to reproduce more or less what traditional solutions provide natively:
The goal here is to tool up strictly with what is necessary for the errors management strategy.
Time is coming to introduce another term: the integration framework. Both lightweight ESB and integration framework notions are very close. Integration framework could be considered as a deployment mode of a lightweight ESB. There is at least a big overlap between them.
Once embedded in an application it takes the role of an Emissary_._ Such solutions are particularly powerfull to equip a Nova (a business domain central application) with mechanisms such as Messaging Gateway and Service Activator. The integration framework then acts as the integration module of a software package. This is typically the positioning of Spring Integration.
Robustness and availability are greatly eased by embedding a lightweight ESB into an application: the integration system is not a bottleneck neither a single point of failure (SPOF) anymore. And over all there is no additional system in the infrastructure.
One limitation with embedding the middleware into an application could be the impossibility to implement flows with a many-to-many cardinality (ie. N => P flows). But in real life flows with a many-to-many cardinality are very uncommon... when they do not result from a design problem.
Lightweight ESBs can be indifferently embedded into an application or deployed as a standalone middleware. They support a large variety of light and heavy deployment technologies. The most pertinent way to deploy lightweight ESBs is using Spring. Avoiding dependency to an heavy container as JBI preserve their flexibility and ease of use.
The world (of ESBs...) is divided in two categories:
The three lightweight ESBs aforementioned belong to the second group. That means they dot not suffer from serialization overhead. Added to the fact that their internal architecture consists of less layers and that these layers are more integrated together, they offer good performances. That being said there is not much surprises: performances are ones expectable from a JEE solution.
The term lightweight ESB itself is a paradox as it is more efficient as a local services bus. Those solutions are perfect for a tactical integration project at the scale of a functional domain. The integration team is all the more reactive since it is interacting with fewer projects.
It is recommended not to define peremptory rules but to diffuse best practices instead. A common shortcut is to expand the integration middleware to the entire organisation at any cost. Often by twisting it to host any kind of flows, or reusing flows that don't have the same business meaning. Moreover the reuse rate of existing flows is significant inside a functional domain but decreases considerably beyond.
Rightly or wrongly, the choice of an ESB is often made at Enterprise level, for strong infrastructure rationalization purpose. Even if the ESB is centralized, try at least not to centralize the integration teams too much. Keep teams autonomous and reactive instead.
Any JEE (Spring ideally) developer can do the job. This is a major point regarding the sourcing strategy: in most cases the deployment of a commercial ESB lead to outsource the expertise. Such alternative solutions are more affordable. The cost of access to the technology is lowered: developers can use their preferred development environment and capitalize on their JEE knowledge, without learning all the specificities of a vendor solution.
The large scale deployment of ESBs always bring the same problem of cost allocation. The allocation on an Activity Based Costing principle is very difficult for shared flows. When confining the middleware to a defined perimeter it becomes a lot easier to identify entities in charge: functional domains themselves.
When a functional domain is responsible for its integration middleware, the time necessary to select a solution is reduced, as less actors are involved in the decision. The choice of an ESB for the entire Enterprise can take months and months. Since purchasing department and technical direction are not in the loop, a short decision cycle increases the time-to-market.
The main lack with lightweight ESBs is the impossibility to implement complex, long-living, business processes. That makes them inappropriate for an Enterprise top-down BPM approach. This limitation apart these light solutions cover all recurring integration requirements, in a more simple way. This is possible because they are built around integration best practices and conventions. If you can't address your issue with Enterprise Integration Patterns, I invite you to double check your requirements. Also note that high level BPM scenarios are marginal in comparison to basic integration. Hopefully, there are more lightweight solutions to come, certainly among commercial ones. The reengineering effort to migrate traditional ESBs to the Cloud already lead vendors to simplify their solutions.
ESBs are often deployed to integrate one and only one application (a shared repository, an ERP, a Nova) with the rest of the Information System. If integration middleware and application are tight coupled anyway, why not deploy both of them as a whole ? Lightweight ESBs can either be embedded into an application or deployed standalone. This is a precious option.
Beyond these technical aspects, the use of a lightweight ESB can bring many organisational benefits, in which:
Lightweight ESBs offer a good trade off between the point-to-point spaghetti-ware and the over-centralized ESB. They are best suited for local initiatives at the scale of a functional domain or a business area. By keeping it tactical, the middleware does not turn into an administrative and technical bottleneck. Ultimately a motto for modern integration could be: make local successes!