SlideShare a Scribd company logo
1 of 43
Download to read offline
Styles of Application Integration
    Using Spring
    Bruce Snyder, Senior Software Engineer, SpringSource/VMware




Friday, July 15, 2011
Integrations Are About Coupling




                                      2

Friday, July 15, 2011
Where Coupling Exists, Concerns Arise

    • Tight coupling is easy
    • Loose coupling can be difficult

    • Tight coupling causes issues in the long run
    • Loose coupling pays off in the long run

    • Integrations are usually tightly coupled
    • Integrations should be loosely coupled

    • Integrations are commonly addressed using commands
    • Integrations should be addressed using events


Friday, July 15, 2011
What is Coupling?

           “... the degree to which each program module relies
           on each one of the other modules”
           (Wikipedia.com)



    • Given two lines of code, A and B, they are coupled when B
      must change behavior only because A changed




                                                                 4

Friday, July 15, 2011
Characteristics Tight Coupling

    •    Components are highly dependent upon one another
    •    Components are directly linked
    •    Changes in one component cause a ripple effect
    •    Less reusability
    •    More difficult to maintain
    •    Does not handle unforeseen change well

    • Examples
          – Clients designed to interact only with specific systems
          – Use of proprietary APIs or commands for interaction
          – Components designed to work specifically with other
            components
                                                                      5

Friday, July 15, 2011
Characteristics of Loose Coupling

    •    Components have little or no knowledge of one another
    •    Components are not directly linked to one another
    •    Changes in one component do not affect other components
    •    Increased reusability
    •    Easier to maintain
    •    More easily handles unforeseen changes

    • Examples
          – Dependence upon interfaces instead of concrete classes
          – Use of DI encourages looser coupling
          – A design using a level of indirection


                                                                     6

Friday, July 15, 2011
Tight Coupling is Easy

    •    App design with tight coupling is more widely understood
    •    App development with tight coupling requires less time
    •    Debugging a tightly coupled app is easier
    •    Benefits of tight coupling are seen immediately
    •    Tightly coupled prototypes commonly live on




                                                                    7

Friday, July 15, 2011
Loose Coupling is Difficult

    • App design with loose coupling is not widely understood
    • App development with loosely coupling requires more
      thought and more time
    • Debugging loosely coupled apps is different
    • Benefits of loose coupling are only seen over time




                                                                8

Friday, July 15, 2011
Integrations and Coupling

    • But it’s easy to write a point-to-point, one-off piece of code
      for integration!
    • Too many disadvantages
          –    Difficult to maintain
          –    No reusability
          –    Every integration is unique
          –    Bites you over time




                                                                  9

Friday, July 15, 2011
Integrations and Coupling

    • But designing integrations to be loosely coupled requires
      too much work!
    • With the right knowledge and preparation, it doesn’t need
      to be this way




                                                              10

Friday, July 15, 2011
Commands vs. Events

    • Commands are not natural
          – Verify credit card
    • Commands are too specific

    • Events are natural
          – Order received
    • Events are more broad
    • Events are what happen in the real world




                                                 11

Friday, July 15, 2011
Enterprise Integration Patterns (EIP)




                        http://enterpriseintegrationpatterns.com/
                                                                    12

Friday, July 15, 2011
Spring Integration

    • Provides both concurrency and messaging
          – Message Endpoints
                 • Connections between services
          – Channel Adapters
                 • Adapter between application and message broker
          – Messaging Gateways
                 • Provides uni-directional or bi-directional messaging
          – Service Activators
                 • Invokes a services based on an incoming message
          – Routers
                 • Determines where to dispatch a message
          – Splitters and Aggregators
                 • Breaks up a message and reassembles it after processing

                                                                             13

Friday, July 15, 2011
Spring Integration

    • Supports
          –    AMQP
          –    Email
          –    File system
          –    Gemfire
          –    JMS
          –    JMX
          –    MongoDB
          –    Redis
          –    Spring Batch
          –    Testing
          –    Web Services

                              14

Friday, July 15, 2011
Spring Integration




                         15

Friday, July 15, 2011
Spring Integration




                         16

Friday, July 15, 2011
Spring Integration




                         17

Friday, July 15, 2011
Spring Integration




                         18

Friday, July 15, 2011
Spring Integration




                         19

Friday, July 15, 2011
Spring Integration




                         20

Friday, July 15, 2011
Spring Integration




                         21

Friday, July 15, 2011
Spring Integration




                         22

Friday, July 15, 2011
Spring Integration




                         23

Friday, July 15, 2011
Spring Integration




                         24

Friday, July 15, 2011
Types of Integration

    • Intra-application integration
    • Inter-application integration
    • External system integration




                                      25

Friday, July 15, 2011
Typical Application Layers




                                 26

Friday, July 15, 2011
Intra-Application Integration




                                    27

Friday, July 15, 2011
Spring Integration Config



   <int:gateway id="sender"
     service-interface="org.bsnyder.spring.integration.simple.Sender"/>

   <int:channel id="orderReceived"/>

   <int:service-activator input-channel="orderReceived" ref="receiver"
   method="receive" />

   <bean id="receiver" class="org.bsnyder.spring.integration.simple.Receiver"/>




                                                                                  28

Friday, July 15, 2011
Intra-Application Integration




                                    29

Friday, July 15, 2011
Spring Integration Config
   <int:gateway id="sender"
     service-interface="org.bsnyder.spring.integration.appa.Sender"/>

   <channel id="orderReceived" />

   <amqp:outbound-channel-adapter channel="orderReceived"
     exchange-name="order.received.exchange"
     routing-key="order.received.binding"
     amqp-template="amqpTemplate" />


   <rabbit:connection-factory id="connectionFactory" />
   <rabbit:template id="amqpTemplate" connection-factory="connectionFactory" />
   <rabbit:admin connection-factory="connectionFactory" />
   <rabbit:queue name="order.received.queue" />
   <rabbit:direct-exchange name="order.received.exchange">
      <rabbit:bindings>
      <rabbit:binding queue="order.received.queue" key="order.received.binding" />
      </rabbit:bindings>
   </rabbit:direct-exchange>


                                                                                     30

Friday, July 15, 2011
Spring Integration Config

   <amqp:inbound-channel-adapter channel="orderReceived"
     queue-names="order.received.queue"
     connection-factory="connectionFactory" />

   <int:service-activator input-channel="orderReceived" ref="receiver"
   method="receive" />

   <bean id="receiver" class="org.bsnyder.spring.integration.appa.Receiver"/>


   <rabbit:connection-factory id="connectionFactory" />
   <rabbit:template id="amqpTemplate" connection-factory="connectionFactory" />
   <rabbit:admin connection-factory="connectionFactory" />
   <rabbit:queue name="order.received.queue" />
   <rabbit:direct-exchange name="order.received.exchange">
      <rabbit:bindings>
      <rabbit:binding queue="order.received.queue" key="order.received.binding" />
      </rabbit:bindings>
   </rabbit:direct-exchange>


                                                                                     31

Friday, July 15, 2011
32

Friday, July 15, 2011
Inter-Application Integration




                                    33

Friday, July 15, 2011
Inter-Application Integration




                                    34

Friday, July 15, 2011
Spring Integration Config
   <int:gateway id="sender"
     service-interface="org.bsnyder.spring.integration.appa.Sender"/>

   <channel id="orderReceived" />

   <amqp:outbound-channel-adapter channel="orderReceived"
     exchange-name="order.received.exchange"
     routing-key="order.received.binding"
     amqp-template="amqpTemplate" />


   <rabbit:connection-factory id="connectionFactory" />
   <rabbit:template id="amqpTemplate" connection-factory="connectionFactory" />
   <rabbit:admin connection-factory="connectionFactory" />
   <rabbit:queue name="order.received.queue" />
   <rabbit:direct-exchange name="order.received.exchange">
      <rabbit:bindings>
      <rabbit:binding queue="order.received.queue" key="order.received.binding" />
      </rabbit:bindings>
   </rabbit:direct-exchange>


                                                                                     35

Friday, July 15, 2011
Spring Integration Config

   <amqp:inbound-channel-adapter channel="orderReceived"
     queue-names="order.received.queue"
     connection-factory="connectionFactory" />

   <int:service-activator input-channel="orderReceived" ref="receiver"
   method="receive" />

   <bean id="receiver" class="org.bsnyder.spring.integration.appb.Receiver"/>


   <rabbit:connection-factory id="connectionFactory" />
   <rabbit:template id="amqpTemplate" connection-factory="connectionFactory" />
   <rabbit:admin connection-factory="connectionFactory" />
   <rabbit:queue name="order.received.queue" />
   <rabbit:direct-exchange name="order.received.exchange">
      <rabbit:bindings>
      <rabbit:binding queue="order.received.queue" key="order.received.binding" />
      </rabbit:bindings>
   </rabbit:direct-exchange>


                                                                                     36

Friday, July 15, 2011
37

Friday, July 15, 2011
External System Integration




                                  38

Friday, July 15, 2011
Spring Integration Config


   <int:gateway id="sender"
     service-interface="org.bsnyder.spring.integration.appa.Sender"/>


   <bean id="ftpClientFactory"
   class="org.springframework.integration.ftp.session.DefaultFtpSessionFactory"
     p:host" value="localhost" p:username" value="${user}" p:password="$
   {password}"/>
   !
   <int:channel id="ftpChannel"/>

   <int-ftp:outbound-channel-adapter id="ftpOutbound"
     channel="ftpChannel"
     remote-directory="/foo/bar/baz/"
     client-factory="ftpClientFactory"/>




                                                                                  39

Friday, July 15, 2011
Spring Integration Config

   <int:channel id="ftpChannel">
      <int:queue/>
   </int:channel>

   <bean id="ftpClientFactory"
      class="org.springframework.integration.ftp.session.DefaultFtpSessionFactory"
      p:host="localhost" p:username="${user}" p:password="${password}"/>
   !
   <int-ftp:inbound-channel-adapter id="ftpInbound"
      channel="ftpChannel" session-factory="ftpClientFactory"
      filename-regex=".*.txt$" auto-create-local-directory="true"
      delete-remote-files="false" remote-directory="/foo/bar/baz/"
      local-directory="file:local-target-dir">
      <int:poller fixed-rate="1000"/>
   </int-ftp:inbound-channel-adapter>

   <int:service-activator input-channel="ftpChannel" ref="receiver" method="receive" />

   <bean id="receiver" class="org.bsnyder.spring.integration.appb.Receiver"/>


                                                                                     40

Friday, July 15, 2011
41

Friday, July 15, 2011
Combined Integration




                           42

Friday, July 15, 2011
Thank You!




           Q&A




Friday, July 15, 2011

More Related Content

Similar to Styles of Applicaton Integration Using Spring

Beyond Horizontal Scalability: Concurrency and Messaging Using Spring
Beyond Horizontal Scalability: Concurrency and Messaging Using SpringBeyond Horizontal Scalability: Concurrency and Messaging Using Spring
Beyond Horizontal Scalability: Concurrency and Messaging Using SpringBruce Snyder
 
Infusion for the birds
Infusion for the birdsInfusion for the birds
Infusion for the birdscolinbdclark
 
2020-Feb: Testing: Cables and Chains
2020-Feb: Testing: Cables and Chains2020-Feb: Testing: Cables and Chains
2020-Feb: Testing: Cables and ChainsMark Windholtz
 
Microservices: The Best Practices
Microservices: The Best PracticesMicroservices: The Best Practices
Microservices: The Best PracticesPavel Mička
 
Ruby and Rails, as secret weapon to build your service-oriented apps
Ruby and Rails,  as secret weapon to build your service-oriented appsRuby and Rails,  as secret weapon to build your service-oriented apps
Ruby and Rails, as secret weapon to build your service-oriented appsFelipe Talavera
 
WE-06-Testing.ppt
WE-06-Testing.pptWE-06-Testing.ppt
WE-06-Testing.pptjaved281701
 
Testing for Logic App Solutions | Integration Monday
Testing for Logic App Solutions | Integration MondayTesting for Logic App Solutions | Integration Monday
Testing for Logic App Solutions | Integration MondayBizTalk360
 
PAC 2019 virtual Joerek Van Gaalen
PAC 2019 virtual Joerek Van GaalenPAC 2019 virtual Joerek Van Gaalen
PAC 2019 virtual Joerek Van GaalenNeotys
 
Building trust within the organization, first steps towards DevOps
Building trust within the organization, first steps towards DevOpsBuilding trust within the organization, first steps towards DevOps
Building trust within the organization, first steps towards DevOpsGuido Serra
 
Mastering Complex Application Deployments
Mastering Complex Application DeploymentsMastering Complex Application Deployments
Mastering Complex Application DeploymentsIBM UrbanCode Products
 
Gartner Infrastructure and Operations Summit Berlin 2015 - DevOps Journey
Gartner Infrastructure and Operations Summit Berlin 2015 - DevOps JourneyGartner Infrastructure and Operations Summit Berlin 2015 - DevOps Journey
Gartner Infrastructure and Operations Summit Berlin 2015 - DevOps JourneyKelly Looney
 
Entity Framework: To the Unit of Work Design Pattern and Beyond
Entity Framework: To the Unit of Work Design Pattern and BeyondEntity Framework: To the Unit of Work Design Pattern and Beyond
Entity Framework: To the Unit of Work Design Pattern and BeyondSteve Westgarth
 
Performance Assurance for Packaged Applications
Performance Assurance for Packaged ApplicationsPerformance Assurance for Packaged Applications
Performance Assurance for Packaged ApplicationsAlexander Podelko
 
Pragmatic Microservices
Pragmatic MicroservicesPragmatic Microservices
Pragmatic MicroservicesRandy Shoup
 
Building The Agile Enterprise - LSSC '12
Building The Agile Enterprise - LSSC '12Building The Agile Enterprise - LSSC '12
Building The Agile Enterprise - LSSC '12Gil Irizarry
 
Agile enterprise integration
Agile enterprise integrationAgile enterprise integration
Agile enterprise integrationSimon Greig
 
JavaSE - The road forward
JavaSE - The road forwardJavaSE - The road forward
JavaSE - The road forwardeug3n_cojocaru
 
Boston MeetUp 10.10
Boston MeetUp 10.10Boston MeetUp 10.10
Boston MeetUp 10.10Solano Labs
 

Similar to Styles of Applicaton Integration Using Spring (20)

Beyond Horizontal Scalability: Concurrency and Messaging Using Spring
Beyond Horizontal Scalability: Concurrency and Messaging Using SpringBeyond Horizontal Scalability: Concurrency and Messaging Using Spring
Beyond Horizontal Scalability: Concurrency and Messaging Using Spring
 
Infusion for the birds
Infusion for the birdsInfusion for the birds
Infusion for the birds
 
2020-Feb: Testing: Cables and Chains
2020-Feb: Testing: Cables and Chains2020-Feb: Testing: Cables and Chains
2020-Feb: Testing: Cables and Chains
 
Microservices: The Best Practices
Microservices: The Best PracticesMicroservices: The Best Practices
Microservices: The Best Practices
 
Ruby and Rails, as secret weapon to build your service-oriented apps
Ruby and Rails,  as secret weapon to build your service-oriented appsRuby and Rails,  as secret weapon to build your service-oriented apps
Ruby and Rails, as secret weapon to build your service-oriented apps
 
WE-06-Testing.ppt
WE-06-Testing.pptWE-06-Testing.ppt
WE-06-Testing.ppt
 
Testing for Logic App Solutions | Integration Monday
Testing for Logic App Solutions | Integration MondayTesting for Logic App Solutions | Integration Monday
Testing for Logic App Solutions | Integration Monday
 
PAC 2019 virtual Joerek Van Gaalen
PAC 2019 virtual Joerek Van GaalenPAC 2019 virtual Joerek Van Gaalen
PAC 2019 virtual Joerek Van Gaalen
 
Building trust within the organization, first steps towards DevOps
Building trust within the organization, first steps towards DevOpsBuilding trust within the organization, first steps towards DevOps
Building trust within the organization, first steps towards DevOps
 
Mastering Complex Application Deployments
Mastering Complex Application DeploymentsMastering Complex Application Deployments
Mastering Complex Application Deployments
 
Gartner Infrastructure and Operations Summit Berlin 2015 - DevOps Journey
Gartner Infrastructure and Operations Summit Berlin 2015 - DevOps JourneyGartner Infrastructure and Operations Summit Berlin 2015 - DevOps Journey
Gartner Infrastructure and Operations Summit Berlin 2015 - DevOps Journey
 
Entity Framework: To the Unit of Work Design Pattern and Beyond
Entity Framework: To the Unit of Work Design Pattern and BeyondEntity Framework: To the Unit of Work Design Pattern and Beyond
Entity Framework: To the Unit of Work Design Pattern and Beyond
 
Performance Assurance for Packaged Applications
Performance Assurance for Packaged ApplicationsPerformance Assurance for Packaged Applications
Performance Assurance for Packaged Applications
 
Pragmatic Microservices
Pragmatic MicroservicesPragmatic Microservices
Pragmatic Microservices
 
Building The Agile Enterprise - LSSC '12
Building The Agile Enterprise - LSSC '12Building The Agile Enterprise - LSSC '12
Building The Agile Enterprise - LSSC '12
 
NYC MeetUp 10.9
NYC MeetUp 10.9NYC MeetUp 10.9
NYC MeetUp 10.9
 
Agile enterprise integration
Agile enterprise integrationAgile enterprise integration
Agile enterprise integration
 
Training - What is Performance ?
Training  - What is Performance ?Training  - What is Performance ?
Training - What is Performance ?
 
JavaSE - The road forward
JavaSE - The road forwardJavaSE - The road forward
JavaSE - The road forward
 
Boston MeetUp 10.10
Boston MeetUp 10.10Boston MeetUp 10.10
Boston MeetUp 10.10
 

More from Bruce Snyder

Enterprise Messaging With Spring JMS
Enterprise Messaging With Spring JMSEnterprise Messaging With Spring JMS
Enterprise Messaging With Spring JMSBruce Snyder
 
ActiveMQ In Action
ActiveMQ In ActionActiveMQ In Action
ActiveMQ In ActionBruce Snyder
 
ActiveMQ In Action - ApacheCon 2011
ActiveMQ In Action - ApacheCon 2011ActiveMQ In Action - ApacheCon 2011
ActiveMQ In Action - ApacheCon 2011Bruce Snyder
 
Using Enterprise Integration Patterns as Your Camel Jockey
Using Enterprise Integration Patterns as Your Camel JockeyUsing Enterprise Integration Patterns as Your Camel Jockey
Using Enterprise Integration Patterns as Your Camel JockeyBruce Snyder
 
Apache ActiveMQ and Apache ServiceMix
Apache ActiveMQ and Apache ServiceMixApache ActiveMQ and Apache ServiceMix
Apache ActiveMQ and Apache ServiceMixBruce Snyder
 
Service-Oriented Integration With Apache ServiceMix
Service-Oriented Integration With Apache ServiceMixService-Oriented Integration With Apache ServiceMix
Service-Oriented Integration With Apache ServiceMixBruce Snyder
 
Messaging With Apache ActiveMQ
Messaging With Apache ActiveMQMessaging With Apache ActiveMQ
Messaging With Apache ActiveMQBruce Snyder
 
Enterprise Messaging With ActiveMQ and Spring JMS
Enterprise Messaging With ActiveMQ and Spring JMSEnterprise Messaging With ActiveMQ and Spring JMS
Enterprise Messaging With ActiveMQ and Spring JMSBruce Snyder
 
Taking Apache Camel For a Ride
Taking Apache Camel For a RideTaking Apache Camel For a Ride
Taking Apache Camel For a RideBruce Snyder
 
Service Oriented Integration With ServiceMix
Service Oriented Integration With ServiceMixService Oriented Integration With ServiceMix
Service Oriented Integration With ServiceMixBruce Snyder
 
Taking Apache Camel For A Ride
Taking Apache Camel For A RideTaking Apache Camel For A Ride
Taking Apache Camel For A RideBruce Snyder
 
Messaging With ActiveMQ
Messaging With ActiveMQMessaging With ActiveMQ
Messaging With ActiveMQBruce Snyder
 
Taking Apache Camel For A Ride
Taking Apache Camel For A RideTaking Apache Camel For A Ride
Taking Apache Camel For A RideBruce Snyder
 

More from Bruce Snyder (14)

Enterprise Messaging With Spring JMS
Enterprise Messaging With Spring JMSEnterprise Messaging With Spring JMS
Enterprise Messaging With Spring JMS
 
ActiveMQ In Action
ActiveMQ In ActionActiveMQ In Action
ActiveMQ In Action
 
ActiveMQ In Action - ApacheCon 2011
ActiveMQ In Action - ApacheCon 2011ActiveMQ In Action - ApacheCon 2011
ActiveMQ In Action - ApacheCon 2011
 
Using Enterprise Integration Patterns as Your Camel Jockey
Using Enterprise Integration Patterns as Your Camel JockeyUsing Enterprise Integration Patterns as Your Camel Jockey
Using Enterprise Integration Patterns as Your Camel Jockey
 
Apache ActiveMQ and Apache ServiceMix
Apache ActiveMQ and Apache ServiceMixApache ActiveMQ and Apache ServiceMix
Apache ActiveMQ and Apache ServiceMix
 
Service-Oriented Integration With Apache ServiceMix
Service-Oriented Integration With Apache ServiceMixService-Oriented Integration With Apache ServiceMix
Service-Oriented Integration With Apache ServiceMix
 
Messaging With Apache ActiveMQ
Messaging With Apache ActiveMQMessaging With Apache ActiveMQ
Messaging With Apache ActiveMQ
 
Enterprise Messaging With ActiveMQ and Spring JMS
Enterprise Messaging With ActiveMQ and Spring JMSEnterprise Messaging With ActiveMQ and Spring JMS
Enterprise Messaging With ActiveMQ and Spring JMS
 
Taking Apache Camel For a Ride
Taking Apache Camel For a RideTaking Apache Camel For a Ride
Taking Apache Camel For a Ride
 
EIP In Practice
EIP In PracticeEIP In Practice
EIP In Practice
 
Service Oriented Integration With ServiceMix
Service Oriented Integration With ServiceMixService Oriented Integration With ServiceMix
Service Oriented Integration With ServiceMix
 
Taking Apache Camel For A Ride
Taking Apache Camel For A RideTaking Apache Camel For A Ride
Taking Apache Camel For A Ride
 
Messaging With ActiveMQ
Messaging With ActiveMQMessaging With ActiveMQ
Messaging With ActiveMQ
 
Taking Apache Camel For A Ride
Taking Apache Camel For A RideTaking Apache Camel For A Ride
Taking Apache Camel For A Ride
 

Recently uploaded

Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024The Digital Insurer
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024Rafal Los
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...apidays
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...Neo4j
 
Automating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps ScriptAutomating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps Scriptwesley chun
 
Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...Enterprise Knowledge
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slidevu2urc
 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024Results
 
What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?Antenna Manufacturer Coco
 
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdfThe Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdfEnterprise Knowledge
 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc
 
Exploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone ProcessorsExploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone Processorsdebabhi2
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsEnterprise Knowledge
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking MenDelhi Call girls
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)Gabriella Davis
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking MenDelhi Call girls
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slidespraypatel2
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Igalia
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024The Digital Insurer
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?Igalia
 

Recently uploaded (20)

Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
 
Automating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps ScriptAutomating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps Script
 
Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slide
 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024
 
What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?
 
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdfThe Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
 
Exploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone ProcessorsExploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone Processors
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI Solutions
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slides
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?
 

Styles of Applicaton Integration Using Spring

  • 1. Styles of Application Integration Using Spring Bruce Snyder, Senior Software Engineer, SpringSource/VMware Friday, July 15, 2011
  • 2. Integrations Are About Coupling 2 Friday, July 15, 2011
  • 3. Where Coupling Exists, Concerns Arise • Tight coupling is easy • Loose coupling can be difficult • Tight coupling causes issues in the long run • Loose coupling pays off in the long run • Integrations are usually tightly coupled • Integrations should be loosely coupled • Integrations are commonly addressed using commands • Integrations should be addressed using events Friday, July 15, 2011
  • 4. What is Coupling? “... the degree to which each program module relies on each one of the other modules” (Wikipedia.com) • Given two lines of code, A and B, they are coupled when B must change behavior only because A changed 4 Friday, July 15, 2011
  • 5. Characteristics Tight Coupling • Components are highly dependent upon one another • Components are directly linked • Changes in one component cause a ripple effect • Less reusability • More difficult to maintain • Does not handle unforeseen change well • Examples – Clients designed to interact only with specific systems – Use of proprietary APIs or commands for interaction – Components designed to work specifically with other components 5 Friday, July 15, 2011
  • 6. Characteristics of Loose Coupling • Components have little or no knowledge of one another • Components are not directly linked to one another • Changes in one component do not affect other components • Increased reusability • Easier to maintain • More easily handles unforeseen changes • Examples – Dependence upon interfaces instead of concrete classes – Use of DI encourages looser coupling – A design using a level of indirection 6 Friday, July 15, 2011
  • 7. Tight Coupling is Easy • App design with tight coupling is more widely understood • App development with tight coupling requires less time • Debugging a tightly coupled app is easier • Benefits of tight coupling are seen immediately • Tightly coupled prototypes commonly live on 7 Friday, July 15, 2011
  • 8. Loose Coupling is Difficult • App design with loose coupling is not widely understood • App development with loosely coupling requires more thought and more time • Debugging loosely coupled apps is different • Benefits of loose coupling are only seen over time 8 Friday, July 15, 2011
  • 9. Integrations and Coupling • But it’s easy to write a point-to-point, one-off piece of code for integration! • Too many disadvantages – Difficult to maintain – No reusability – Every integration is unique – Bites you over time 9 Friday, July 15, 2011
  • 10. Integrations and Coupling • But designing integrations to be loosely coupled requires too much work! • With the right knowledge and preparation, it doesn’t need to be this way 10 Friday, July 15, 2011
  • 11. Commands vs. Events • Commands are not natural – Verify credit card • Commands are too specific • Events are natural – Order received • Events are more broad • Events are what happen in the real world 11 Friday, July 15, 2011
  • 12. Enterprise Integration Patterns (EIP) http://enterpriseintegrationpatterns.com/ 12 Friday, July 15, 2011
  • 13. Spring Integration • Provides both concurrency and messaging – Message Endpoints • Connections between services – Channel Adapters • Adapter between application and message broker – Messaging Gateways • Provides uni-directional or bi-directional messaging – Service Activators • Invokes a services based on an incoming message – Routers • Determines where to dispatch a message – Splitters and Aggregators • Breaks up a message and reassembles it after processing 13 Friday, July 15, 2011
  • 14. Spring Integration • Supports – AMQP – Email – File system – Gemfire – JMS – JMX – MongoDB – Redis – Spring Batch – Testing – Web Services 14 Friday, July 15, 2011
  • 15. Spring Integration 15 Friday, July 15, 2011
  • 16. Spring Integration 16 Friday, July 15, 2011
  • 17. Spring Integration 17 Friday, July 15, 2011
  • 18. Spring Integration 18 Friday, July 15, 2011
  • 19. Spring Integration 19 Friday, July 15, 2011
  • 20. Spring Integration 20 Friday, July 15, 2011
  • 21. Spring Integration 21 Friday, July 15, 2011
  • 22. Spring Integration 22 Friday, July 15, 2011
  • 23. Spring Integration 23 Friday, July 15, 2011
  • 24. Spring Integration 24 Friday, July 15, 2011
  • 25. Types of Integration • Intra-application integration • Inter-application integration • External system integration 25 Friday, July 15, 2011
  • 26. Typical Application Layers 26 Friday, July 15, 2011
  • 27. Intra-Application Integration 27 Friday, July 15, 2011
  • 28. Spring Integration Config <int:gateway id="sender" service-interface="org.bsnyder.spring.integration.simple.Sender"/> <int:channel id="orderReceived"/> <int:service-activator input-channel="orderReceived" ref="receiver" method="receive" /> <bean id="receiver" class="org.bsnyder.spring.integration.simple.Receiver"/> 28 Friday, July 15, 2011
  • 29. Intra-Application Integration 29 Friday, July 15, 2011
  • 30. Spring Integration Config <int:gateway id="sender" service-interface="org.bsnyder.spring.integration.appa.Sender"/> <channel id="orderReceived" /> <amqp:outbound-channel-adapter channel="orderReceived" exchange-name="order.received.exchange" routing-key="order.received.binding" amqp-template="amqpTemplate" /> <rabbit:connection-factory id="connectionFactory" /> <rabbit:template id="amqpTemplate" connection-factory="connectionFactory" /> <rabbit:admin connection-factory="connectionFactory" /> <rabbit:queue name="order.received.queue" /> <rabbit:direct-exchange name="order.received.exchange"> <rabbit:bindings> <rabbit:binding queue="order.received.queue" key="order.received.binding" /> </rabbit:bindings> </rabbit:direct-exchange> 30 Friday, July 15, 2011
  • 31. Spring Integration Config <amqp:inbound-channel-adapter channel="orderReceived" queue-names="order.received.queue" connection-factory="connectionFactory" /> <int:service-activator input-channel="orderReceived" ref="receiver" method="receive" /> <bean id="receiver" class="org.bsnyder.spring.integration.appa.Receiver"/> <rabbit:connection-factory id="connectionFactory" /> <rabbit:template id="amqpTemplate" connection-factory="connectionFactory" /> <rabbit:admin connection-factory="connectionFactory" /> <rabbit:queue name="order.received.queue" /> <rabbit:direct-exchange name="order.received.exchange"> <rabbit:bindings> <rabbit:binding queue="order.received.queue" key="order.received.binding" /> </rabbit:bindings> </rabbit:direct-exchange> 31 Friday, July 15, 2011
  • 33. Inter-Application Integration 33 Friday, July 15, 2011
  • 34. Inter-Application Integration 34 Friday, July 15, 2011
  • 35. Spring Integration Config <int:gateway id="sender" service-interface="org.bsnyder.spring.integration.appa.Sender"/> <channel id="orderReceived" /> <amqp:outbound-channel-adapter channel="orderReceived" exchange-name="order.received.exchange" routing-key="order.received.binding" amqp-template="amqpTemplate" /> <rabbit:connection-factory id="connectionFactory" /> <rabbit:template id="amqpTemplate" connection-factory="connectionFactory" /> <rabbit:admin connection-factory="connectionFactory" /> <rabbit:queue name="order.received.queue" /> <rabbit:direct-exchange name="order.received.exchange"> <rabbit:bindings> <rabbit:binding queue="order.received.queue" key="order.received.binding" /> </rabbit:bindings> </rabbit:direct-exchange> 35 Friday, July 15, 2011
  • 36. Spring Integration Config <amqp:inbound-channel-adapter channel="orderReceived" queue-names="order.received.queue" connection-factory="connectionFactory" /> <int:service-activator input-channel="orderReceived" ref="receiver" method="receive" /> <bean id="receiver" class="org.bsnyder.spring.integration.appb.Receiver"/> <rabbit:connection-factory id="connectionFactory" /> <rabbit:template id="amqpTemplate" connection-factory="connectionFactory" /> <rabbit:admin connection-factory="connectionFactory" /> <rabbit:queue name="order.received.queue" /> <rabbit:direct-exchange name="order.received.exchange"> <rabbit:bindings> <rabbit:binding queue="order.received.queue" key="order.received.binding" /> </rabbit:bindings> </rabbit:direct-exchange> 36 Friday, July 15, 2011
  • 38. External System Integration 38 Friday, July 15, 2011
  • 39. Spring Integration Config <int:gateway id="sender" service-interface="org.bsnyder.spring.integration.appa.Sender"/> <bean id="ftpClientFactory" class="org.springframework.integration.ftp.session.DefaultFtpSessionFactory" p:host" value="localhost" p:username" value="${user}" p:password="$ {password}"/> ! <int:channel id="ftpChannel"/> <int-ftp:outbound-channel-adapter id="ftpOutbound" channel="ftpChannel" remote-directory="/foo/bar/baz/" client-factory="ftpClientFactory"/> 39 Friday, July 15, 2011
  • 40. Spring Integration Config <int:channel id="ftpChannel"> <int:queue/> </int:channel> <bean id="ftpClientFactory" class="org.springframework.integration.ftp.session.DefaultFtpSessionFactory" p:host="localhost" p:username="${user}" p:password="${password}"/> ! <int-ftp:inbound-channel-adapter id="ftpInbound" channel="ftpChannel" session-factory="ftpClientFactory" filename-regex=".*.txt$" auto-create-local-directory="true" delete-remote-files="false" remote-directory="/foo/bar/baz/" local-directory="file:local-target-dir"> <int:poller fixed-rate="1000"/> </int-ftp:inbound-channel-adapter> <int:service-activator input-channel="ftpChannel" ref="receiver" method="receive" /> <bean id="receiver" class="org.bsnyder.spring.integration.appb.Receiver"/> 40 Friday, July 15, 2011
  • 42. Combined Integration 42 Friday, July 15, 2011
  • 43. Thank You! Q&A Friday, July 15, 2011