WSO2 has a product stack which can be used in different integration scenarios with different architectures. Any how all of those products are built in well managed way. There is no single code which is duplicated. All our products are collection of software libraries written by WSO2 engineers or third party open source libraries. So we have well defined libraries which are used by set of products. Carbon Transport is a such library that many of the products uses to managed transport layer.
When it comes to middleware layer definitely it should have interface for receive and send messages which are coming through networking layer. So receiving and sending is the main objective of the Carbon-Transport. It is written on top of the Netty.Netty is a lightweight high performing network application library which is based on pipeline architecture. I have explained the concepts of Netty in my previous article. Following is the architecture of the Carbon Transport.
Basic architectural components
- Netty Pipeline
As I mentioned earlier we have used Netty as a underlying library for create interface in between networking layer and application layer. So at the bootstrapping phase we are parsing the configuration file and pump relevant configuration parameters into Netty ServerBootstrap and Client Bootstrap for listener and sender side initialization.
When creating Server or Client side Bootstraps we need to implement ChannelInitializer which has the set of Netty Handlers which are used to create Netty Pipeline. So Pipeline represents each and every accepted socket and all the events related to that socket are handled through that pipeline.So if we have 100 connections then 100 pipleine objects are created .
So in carbon transport we are using HTTPRequest and Response encoders , decoders as well streamers and object aggregators. In order to support SSL Netty has a inbuilt SSLHandler which can be used by passing SSLEngine according to our customizations. As a final handler our custom handler implementation is engaged and it is used as the interface between Netty Pipeline and the Messaging Engine.
- Application Level Threads
We have used both WorkerPool, based on Executor Services and a Disruptor thread model. WorkerPool is used as a default thread model and for specific scenarios like for passthru scenarios we can enable the disruptor thread model. Disruptor is a locking free ring buffer which can be used to communicate in between two threads in lock free manner. Actually Disruptor performs well compared with Queue based implementations but there should be restricted environment such as Disruptor thread should run in high priority and other threads should not interrupt Disruptor threads. I will discuss Disruptor based thread models in incoming articles. So we have threadpool or Disruptor as application level threads for where messaging engine is operated.
- Connection Pools
We have used connection pools for sender side so by using that we can reused already created connections with the back end which avoids unnecessary connection creation with in BackEnd endpoints. We are using three connection pooling strategies
- Per Source Channel Connection Pool
- Pool of Pools
- One Pool
According to the configuration we can select out of one of the above and for high speed messaging we can use Per Source Channel Connection Pool where we maintained the target connections for each and every incoming connection.So scope is limited to source channel and it will reduce the contention for access connections.
Pool of Pools has a bit higher contention when retrieving connections and we are using Apache commons pool as the Source for Pool implementation. This keeps a set of isolated pools and those pools can have duplicate entries for same endpoint .So contention is only within the pool.
When we used One pool performance may be reduced but you can keep minimum number of connections with the backend endpoints.
So those are the basic concepts behind the implementation of the Carbon Transport.
No comments:
Post a Comment