Category Archives: Spring

What is spring integration and how can it help solve enterprise integration challenges


Over past couple of years I have been heavily involved with enterprise integration. Have worked with content management applications, enterprise telephony and many other domains –one of the key challenges faced by me is interaction and integration with external systems. Let me explain a bit, in an era of “as a service” model, an application need to integrate with n number of heterogeneous system to come in totality. Let’s take a quick example, typically new publishing might source content from one vendor, images from Instagram account, social feeds from Twitter/Facebook etc. As you might have observed –these systems are “totally” disconnected. To emphasize my point –while developing these module no one might have an idea that it could be even useful for others! Obvious enough that when we try to integrate these we will run into a hell lot of issues, let’s try to bullet out a few:

  1. How to interact with the other module? Shared file, shared DB, HTTP protocol, proprietary protocol –the list is endless, should we sit down and write all of these “Adapters”?
  2. How these systems will understand data? Data transformation –should we write converters for all the permutation combination of data formats?
  3. Definition of failure is always subjective –some will log it and ask user to try next time while other may rollback all previous step. How do we deal when we have to integrate system which follow different paradigm for failure?
  4. Rate of processing – areal time application may churn data pretty fast, what if the consumer is slow? How do we deal with that?

These are just a sneak peek in issues which I face every day. And not only me, but tons of developer out there –can we say it as an era of service integrations! And what happens when a mass faces similar kind of issue –yep, we develop frameworks, tool, so that it can be reused.
In the mess of inequality, we need a sort of mediator which can orchestrate the interaction. If all is successful – well it’s nice, but if something goes wrong –it also brings them on last stable state! And this where enterprise integration patterns gains its relevance. There are many implementations of these patterns –ApacheCamel, Spring Integration etc., but I have primarily worked with Spring Integration. Reason, we have existing Spring ecosystem, its very lightweight, does not need a separate process space, and over all very easy to use and integrate.

I have written a quick “getting started” blog on spring integration and then to further share my experience with this topic, I have jotted down, basic theory, real time issues and their ready to implement code in a book “Spring Integration Essentials” available at amazon and packtpub.
It’s not a theory book –rather “learn by example” and you will find running code for real time scenarios. Some quick examples:

  1. How to transform message from one format to other –for example XML to a java bean; key is without writing explicit code –instead suing the components from spring integration
  2. How to connect to FTP server by passing just the connection credential –not a single line of input output code
  3. Interact with JMS –again using adapters from spring and not custom code
  4. Send out emails
  5. Get feeds from twitter
  6. Triggering, Controlling and Monitoring Batch jobs
  7. Managing the performance of sporing integration components
  8. You will find code for each scenario which is executable –and at end there is an end to end real time scenario implementation

Check it out at amazon and packtpub. , and code samples at Github -please free to connect with me for any clarification or issues

Spring data -yet another abstraction -quickly getting started


We started with JDBC, then ORM which abstracted the underlying relation DB. Then came JPA -which abstracted the underlying ORM. Now Spring Data

But the kind of versatility we see today in data storage -relational, distributed, nosql and others, to me Spring Data seems to server the purpose.

It abstracts the CRUD for “different” type of data as relational, nosql and just by coding to appropriate interface CRUD operations can be achieved. For getting started use this link for configuring the entity manage, transaction manager -basically the setup stuff.

Write a DaoInterface -here the magic goes, the extended interface decides type of data , relational, nosql etc.

public interface TestDao extends CrudRepository<TestData , Integer> {
}

And then for CRUD operations use this Interface :

@Service
public class TestService{
    @Autowired
    TestDao testDao;
 	public boolean saveTestData(TestData testData){
    	if(testData!=null){
    		testDao.save(user);
                return true;
        }
    	return false;
    }
}
     @Entity
	@Table (name="testtable")
	public class TestData {
	 
	    @Id
	    @GeneratedValue
	    private Long id;
	     
	    public Long getId() {
	        return id;
	    }
	 
	    public void setId(Long id) {
	        this.id = id;
	    }

I found it simple, yet flexible and power full considering the fact that although projects start with SQL, but down the line NOSQL is definitely on their road map -this abstraction will ensure least throwaway code!

Looking up spring beans defined in java configuration classes


Recently I got rid of XML files in Spring app used for configuration by using annotated classes. A basic issue -how to “lookup” these instance if required, took me some time. The good old way with XML

AbstractApplicationContext ctx = new ClassPathXmlApplicationContext("/META-INF/application-context-root.xml");

It’s still simple, use a different class with configuration class as argument

ApplicationContext context = new AnnotationConfigApplicationContext(RootConfig.class);
sessionManager = (SessionManager) context.getBean("sessionManager");

Solving character encoding issue with Spring REST


While working on one of spring integration project, we fetched an XML using REST service and while we dumped it, we observed that many of characters were jumbled -which means encoding setting was screwed up. Spring integration configuration code

<int-http:outbound-gateway request-channel="testChannel"
		url="${test.url}" http-method="GET" expected-response-type="java.lang.String"
		reply-channel="glHeaderEnricher" charset="iso-8859-1">
		<int-http:uri-variable name="site_code"
			expression="payload" />
	</int-http:outbound-gateway>

As above mentioned, we were setting the expected char set as well.
“http:outbound-gateway” from Spring is nothing but a wrapper around Spring REST template, so started investigating what going on with REST template. REST template has option to inject message converters, by default converters which get registered are ByteArrayHttpMessageConverter, StringHttpMessageConverter, and ResourceHttpMessageConverter.

In spring integration configuration we had set “expected-response-type=”java.lang.String”” was causing StringHttpMessageConverter to be selected and used, and hence even before the XML payload reached our system it had lost it’s encoding.

Solution? using ByteArrayHttpMessageConverter, which can be done by setting

<int-http:outbound-gateway request-channel="testChannel"
		url="${test.url}" http-method="GET" expected-response-type="byte[]"
		reply-channel="glHeaderEnricher" charset="iso-8859-1">
		<int-http:uri-variable name="site_code"
			expression="payload" />
</int-http:outbound-gateway>

Once read as a raw byte it can be converted to string in any encoding.

Setting timeout for REST and SOAP webservices in Spring


I got in a situation where one of the external providers were missing their SLA and instead of their agreed 3 sec (hypothetical) for response, webservice was taking ~1 minute.
In this situation, the component was taking a lot of time to load -slowing down the whole page response. Following are the way to set the timeout parameter:

  • Setting JVM parameter (This will work ONLY for RESTfull services -Basically services dependent on JDK HTTP client)
    1. -Dsun.net.client.defaultConnectTimeout=1000 (Time to establish connection in millisec)
    2. -Dsun.net.client.defaultReadTimeout=1000 (Time to read content in millisec)

This works because Spring template by default uses HTTPClient from JDK, if the factory class has been overridden to non JDK class it will fail

  • Injecting the parameters for REST template
  • 	<bean id="restTemplate" class="org.springframework.web.client.RestTemplate">
    		<constructor-arg>
        		<bean class="org.springframework.http.client.HttpComponentsClientHttpRequestFactory">
        			<property name="readTimeout" value="100" />
        			<property name="connectTimeout" value="100"/>
       		 	</bean>
    		</constructor-arg>
    	</bean>   
    

    Be sure not to use the depricated class “org.springframework.http.client.CommonsClientHttpRequestFactory”, otherwise it throws an error while setting connectTimeout

  • Injecting the parameters for SOAP Service
  •         <property name="messageSender">
                <bean
                    class="org.springframework.ws.transport.http.HttpComponentsMessageSender">
                         <property name="connectionTimeout" value="10" />
                  <property name="readTimeout" value="100" />
                </bean>
            </property>
    

    Spring Integration -Getting started tutorial


    A brief update, over past years I have continued working with spring integration and in quest to share my experience I have put challenges faced by me and it’s programmatic solution in a book name spring integration essentials which is available at amazon and packtpub. , and code samples at Github -please free to connect with me for any clarification or issues.

    It’s NOT a theory book, you can directly dive into using code samples (they are available on Github, so you can try experimenting with them right away)

    Let’s start with our Introduction 🙂
    ——————————————————————————————————————
    I worked on one of the projects using spring integration. thought of sharing a quick hands on tutorial. I will cover following along with code snippet.

    1. Introduction
      • What problem does Spring Integration solves –Enterprise Application Integration
      • A brief overview of Spring Integration
      • What are alternatives
      • Why Spring Integration over other
    2. Getting Started
      • Main components (Message, Message Channel, Message End Point)
      • Message Endpoints (Transformer, Filter, Activator, Adapter)
    3. Scaling UP
      • How to implement multiple executors
    4. Infrastructural Support
      • JMX
    5. IDE -STS
    6. Basic hands On
      • A Example with REST based API and transformer
    • Introduction
    • Enterprise application have heterogeneous interfaces and applications, for example accounting, payroll, reporting, maintenance etc. which have been developed over a period of time with using different platforms (e.g. financial in COBOL, payroll in J2ee, maintenance in c/c++ etc. )

      Intercommunication between these modules have always been a challenge. How a c/c++ application talk with Java app, how CORBA and SOAP can be made seamless, how a File system and DB interaction be made possible -these all have been tried in multiple different ways. Enterprise Application Integration is an effort to address these kind of scenario.

        Major EAI approaches are

        • File Transfer: System interacts via files. For example an external provider can put files on a FTP
          server which contains input for other application.

        • Shared Database: Two systems interact via same database. For example in a SaaS environment,
          catalogue of product can be stored at same DB location which different vendors can use.
        • Remote Procedure Call: We see this everyday –Avatars are SOAP, REST most talked and “Hot”
        • Messaging: Two words- JMS architecture

      enterprise pattern defines major patterns for enterprise integration. Spring Integration is one of the implementation of the enterprise patterns.
      When we talk of heterogeneous communication, additional challenges comes in terms of synchronous and asynchronous communication mode. One of endpoints may not be available at time of interaction, or may be less responsive -this necessitates a need for an orchestrator which can retry, communication back, audit and do other stuff in role of a mediator. Here enters Enterprise Service Bus (ESB). ESB acts as mediator between these heterogeneous interfaces.

    • A brief introduction of Spring Integration:
    • Quoted from official Spring Integration
      “Spring Integration provides an extension of the Spring programming model to support the well-known Enterprise Integration Patterns. It enables lightweight messaging within Spring-based applications and supports integration with external systems via declarative adapters. Those adapters provide a higher-level of abstraction over Spring’s support for remoting, messaging, and scheduling. Spring Integration’s primary goal is to provide a simple model for building enterprise integration solutions while maintaining the separation of concerns that is essential for producing maintainable, testable code.”

    • Alternatives:
    • As discussed earlier, there have been numerous attempts to address the EAI. It’s difficult to list all –but two examples are.
      Mule ESB : It is a container, application need to be dropped in to leverage its support.
      Service Mix: It is another ESB, having a heavy footprint and trying to address lot of issues with lot of modules (OSGI Bundles)!
      Description of any of the above is beyond scope.

    • Why Spring Integration:
      • Does not need a container or separate process space, can be invoked in existing program
      • Very light footprint, it is just a JAR which can be dropped with WAR or standalone systems
      • spring framework module, goes easily with existing spring and java project
    • Getting started
      • An ESB must support following components

        • Routing: It should be able to route messages across different endpoints based on configured rules or conditional logic.
        • Messaging: Convert message to and from different incompatible format to a normalized format.
        • Mediation: Making communication possible between heterogeneous interfaces.
        • Complex Event Processing (CEP): Capability to listen for events and trigger it as well.
        • Invocation: It should be able to orchestrate service interaction and invocation.

      It should also support logging, auditing, authentication (security), and management, etc, above and beyond the services listed above.

    • What are the major components supported by Spring:
    • (Definitions and images are standard and taken from Spring Integration Reference. The purpose is to provide quick reference)
      Message
      In Spring Integration, a Message is a generic wrapper for any Java object combined with metadata used
      by the framework while handling that object. It consists of a payload and headers. The payload can be of any type and the headers hold commonly required information such as id, timestamp, correlation id, and return address.

      Message Channel
      A Message Channel represents the “pipe” of a pipes-and-filters architecture. Producers send Messages to a channel, and consumers receive Messages from a channel. The Message Channel therefore decouples the messaging components, and also provides a convenient point for interception and monitoring of Messages.
      A Message Channel may follow either Point-to-Point or Publish/Subscribe semantics. With a Point-to-Point channel, at most one consumer can receive each Message sent to the channel. Publish/Subscribe channels, on the other hand, will attempt to broadcast each Message to all of its subscribers.

      Should channels buffer the messages?
      Pollable Channels are capable of buffering Messages within a queue. The advantage of buffering is that it allows for throttling the inbound Messages and thereby prevents overloading a consumer.
      On the other hand, a consumer connected to a Subscribable Channel is simply Message-driven.

    • Message Endpoints
      A Message Endpoint represents the “filter” of a pipes-and-filters architecture. As mentioned above, the endpoint’s primary role is to connect application code to the messaging framework and to do so in a noninvasive manner. In other words, the application code should ideally have no awareness of the Message objects or the Message Channels. This is similar to the role of a Controller in the MVC paradigm. Just as a Controller handles HTTP requests, the Message Endpoint handles Messages. Just as Controllers are mapped to URL patterns, Message Endpoints are mapped to Message Channels.
      The goal is the same in both cases: isolate application code from the infrastructure.

      Typical endpoints:

      • Transformer
      • A Message Transformer is responsible for converting a Message’s content or structure and returning the modified Message. Probably the most common type of transformer is one that converts the payload of the Message from one format to another (e.g. from XML Document to java.lang.String).

        Typical use case : Convert XML and File based payloads to Domain objects.

      • Filter
      • A Message Filter determines whether a Message should be passed to an output channel at all. This simply requires a boolean test method that may check for a particular payload content type, a property value, the presence of a header, etc.

        Typical use case: Drop all message which does not meet the minimum criteria

      • Router
      • A Message Router is responsible for deciding what channel or channels should receive the Message next (if any).

        Typical use case: If a XML is parsed successfully, it is passed on to next channel for further processing else is routed on a retry channel.

      • Splitter
      • A Splitter is another type of Message Endpoint whose responsibility is to accept a Message from its input channel, split that Message into multiple Messages, and then send each of those to its output channel.

        Typical use case: After fetching list of files from a remote FTP server, list of files is put on a splitter, which then puts it on a gateway –one by one, so that each file can be fetched.

      • Aggregator
      • Basically a mirror-image of the Splitter, the Aggregator is a type of Message Endpoint that receives multiple Messages and combines them into a single Message. Spring Integration provides a completion strategy as well as configurable settings for timeout, whether to send partial results upon timeout, and the discard channel.

        Typical use case: PDF and related images are available from FTP server. Aggregator is used to wait for both (PDF and associated JPEG) of them to be available –correlation strategy decides if both are available or not. Once available it is passed on for further processing.

      • Service Activator
      • A Service Activator is a generic endpoint for connecting a service instance to the messaging system. The input Message Channel must be configured, and if the service method to be invoked is capable of returning a value, an output Message Channel may also be provided. The output channel is optional, since each message may also provide its own ‘Return Address’ header. This same rule applies for all consumer endpoints channel specified in the Message’s “return address” if available.

        Typical use case: All business processing done in service activator, for example persistence.

      • Channel Adapter
      • A Channel Adapter is an endpoint that connects a Message Channel to some other system or transport. Channel Adapters may be either inbound or outbound.
        An inbound “Channel Adapter” endpoint connects a source system to a MessageChannel

        An outbound “Channel Adapter” endpoint connects a MessageChannel to a target system.

      • Threading support:
      • Multiple instances of service activator can be configured to work on same channel. This will help in avoiding build up of channel. For optimal performance of threading, polling interval and max messages per poll should be set appropriately. Lets say, requirement is to process ~7k files in an hour–thread pool executor have been implemented to process items parallel y. A sample code:

      • Infrastructural Support
        • JMX
        • Sing line of configuration exposes all of the channels on standard JMX console.
        • Sample code snippet:
          • ‹context:mbean-server/›
          • ‹int-jmx:mbean-export id=”integrationMbeanExporter”/›

      • STS Visual Editor –
      • It can depict the Integration flow diagrammatically.

        • An in bound channel adapter post dummy message on trigger channel
        • HTTP outbound gateway listens on trigger channel and initiates a HTTP request as soon as channel gets some data
        • HTTP outbound gateway writes its response to HTTP response channel.
        • Transformer is connected to HTTP response channel, which transforms the message and passes on to a persister channel
        • Service Activator takes input from persister channel and performs business logic.
      • Basic hands On -A small code example
      • It is a code example as per above flow. Download the code hosted at Github. It is a maven project -download it and import it as a maven project. Details of class files:

        • Main.java : main class, this boots up the application.
        • InboundAdapter.java : Post dummy message on the trigger channel
        • SimpleTransformer.java :Transformer, which transforms the message –it just adds some custom string. It can be more meaning full as transforming to domain object.
        • HttpResponsePersisterService.java : Service activator –here business logic as persistence can go. For e.g. have just logged it in a log file.
        • spring-sample-app\src\main\resources\META-INF\application-context-root.xml : All the configurations for adapter, transformer and service activator here. Quite self explanatory
        • spring-sample-app\src\main\resources\log4j.properties : Log file settings.

        ——————————————————————————————————————
        A brief update, over past years I have continued working with spring integration and in quest to share my experience I have put challenges faced by me and it’s programmatic solution in a book name spring integration essentials which is available at amazon and packtpub. , and code samples at Github -please free to connect with me for any clarification or issues.

        It’s NOT a theory book, you can directly dive into using code samples (they are available on Github, so you can try experimenting with them right away)

    Moving property files outside jar in spring standalone application


    In one of Spring standalone project, we needed to move the property files out of the jar for easy configurability.
    I followed following steps:
    1. Move property files out of JAR and put in a directory say “target/lib”

    		<plugin>
    	           <artifactId>maven-antrun-plugin</artifactId>
    	           <executions>
    	             <execution>
    	               <phase>validate</phase>
    	               <goals>
    	                 <goal>run</goal>
    	               </goals>
    	               <configuration>
    	                 <tasks>
    				<copy todir="target/lib" overwrite="true">
    					<fileset dir="src/main/resources/">
    						<include name="*.properties"/>
    						<include name="*.xml"/>
    					</fileset>
    				</copy>
    	                 </tasks>
    	               </configuration>
    	             </execution>
    	           </executions>
            	 </plugin>
    

    2. Exclude inclusion of files from the JAR. This will include only .hbm files in resource and any XML file in META-INF (I wanted to keep application-context.xml used by spring inside JAR)

    			<resource>
    				<directory>${basedir}/src/main/resources</directory>
    				<filtering>true</filtering>	
    				<includes>
    					<include>**/*.hbm.xml</include>
    					<include>META-INF/*.xml</include>
    				</includes>
    			</resource>
    

    3. Use maven-jar plugin to include class path information in MANIFEST.MF. This one is MOST important

    	        <plugin>
    	            <groupId>org.apache.maven.plugins</groupId>
    	            <artifactId>maven-jar-plugin</artifactId>
    	            <configuration>
    	                <archive>
    	                    <manifest>
    	                        <addClasspath>true</addClasspath>
    	                        <classpathPrefix>lib/</classpathPrefix>
                                           <mainClass>
                                                 com.usat.digitalportal.service.impl.BootStrap
                                            </mainClass>
    	                    </manifest>
    	                    <manifestEntries>
               					 <Class-Path>. lib</Class-Path>
            			</manifestEntries>
    	                </archive>
    	            </configuration>
    	        </plugin> 
    

    a. Use “classpathPrefix” to specify folder name in which all properties will be placed.
    b. Use “Class-Path” to specify the folder. “.” Indicate current folder, while “lib” specifies “lib” folder in same directory as JAR (I have used lib).
    4. Changes in spring application-context.xml
    a. Add line to look for property file in declared class path

    <context:property-placeholder location="classpath*:**/settings.properties, classpath*:**/usat.properties” />	   
    

    b. Add line to import resources from class path

    		<import resource="classpath*:**/dao-config.xml"/>	 
    

    This is all which is needed. Run maven target as –X clean install and it should Generate a lib folder