• Stars
    star
    2,267
  • Rank 19,493 (Top 0.4 %)
  • Language
    Java
  • Created over 12 years ago
  • Updated 2 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

You are looking for examples, code snippets, sample applications for Spring Integration? This is the place.

Spring Integration Samples

Welcome to the Spring Integration Samples repository which provides 50+ samples to help you learn Spring Integration. To simplify your experience, the Spring Integration samples are split into 4 distinct categories:

  • Basic
  • Intermediate
  • Advanced
  • Applications
  • DSL

Inside of each category you'll find a README.md file, which will contain a more detailed description of that category. Each sample also comes with its own README.md file explaining further details, e.g. how to run the respective sample.

| For additional samples, please also checkout the Spring Integration Extensions project as it also provides numerous samples.

Happy Integration!

Note

This (main) branch requires Spring Integration 6.0 or above. For samples running against earlier versions of Spring Integration, use the 5.5.x and other branches.

The project requires now Java 17 or above. To open the project in the IDE, use its import option against a build.gradle file from the root project directory.

Related GitHub projects

Community Sample Projects

Categories

Below is a short description of each category.

DSL

This directory holds demos/samples for Spring Integration 4.0 Java Configuration as well as the Java DSL Extension.

Basic

This is a good place to get started. The samples here are technically motivated and demonstrate the bare minimum with regard to configuration and code to help you to get introduced to the basic concepts, API and configuration of Spring Integration. For example, if you are looking for an answer on how to wire a Service Activator to a Channel or how to apply a Gateway to your message exchange or how to get started with using the MAIL or XML module, this would be the right place to find a relevant sample. The bottom line is that this is a good starting point.

  • amqp - Demonstrates the functionality of the various AMQP Adapters
  • barrier - Shows how to suspend a thread until some asynchronous event occurs
  • control-bus - Demonstrates the functionality of the Control Bus
  • enricher - This sample demonstrates how the Enricher components can be used
  • feed - Demonstrates the functionality of the Feed Adapter (RSS/ATOM)
  • file - Demonstrates aspects of the various File Adapters (e.g. File Inbound/Outbound Channel Adapters, file polling)
  • ftp - Demonstrates the FTP support available with Spring Integration
  • helloworld - Very simple starting example illustrating a basic message flow (using Channel, ServiceActivator, QueueChannel)
  • http - Demonstrates request/reply communication when using a pair of HTTP Inbound/Outbound gateways
  • jdbc - Illustrates the usage of the Jdbc Adapters, including object persistence and retrieval
  • jms - Demonstrates JMS support available with Spring Integration
  • jmx - Demonstrates JMX support using a JMX Attribute Polling Channel and JMX Operation Invoking Channel Adapter
  • jpa - Shows the usage of the JPA Components
  • mail - Example showing IMAP and POP3 support
  • mqtt - Demonstrates the functionality of inbound and outbound MQTT Adapters
  • mongodb - Shows how to persist a Message payload to a MongoDb document store and how to read documents from MongoDb
  • oddeven - Example combining the functionality of Inbound Channel Adapter, Filter, Router and Poller
  • quote - Example demoing core EIP support using Channel Adapter (Inbound and Stdout), Poller with Interval Triggers, Service Activator
  • sftp - Demonstrating SFTP support using SFTP Inbound / Outbound Channel Adapters
  • tcp-amqp - Demonstrates basic functionality of bridging the Spring Integration TCP Adapters with Spring Integration AMQP Adapters
  • tcp-broadcast - Demonstrates broadcasting a message to multiple connected TCP clients.
  • tcp-client-server - Demonstrates socket communication using TcpOutboundGateway, TcpInboundGateway and also uses a Gateway and a Service Activator
  • tcp-with-headers - Demonstrates sending headers along with the payload over TCP using JSON.
  • testing-examples - A series of test cases that show techniques to test Spring Integration applications.
  • twitter - Illustrates Twitter support using the Twitter Inbound Channel Adapter, Twitter Inbound Search Channel Adapter, Twitter Outbound Channel Adapter
  • ws-inbound-gateway - Example showing basic functionality of the Web Service Gateway
  • ws-outbound-gateway - Shows outbound web services support using the Web Service Outbound Gateway, Content Enricher, Composed Message Processor (Chain)
  • xml - Example demonstrates various aspects of the Xml support using an XPath Splitter, XPath Router, XSLT Transformer as well as XPath Expression support
  • xmpp - Show the support for XMPP (formerly known as Jabber) using e.g. GoogleTalk

Intermediate

This category targets developers who are already more familiar with the Spring Integration framework (past getting started), but need some more guidance while resolving more advanced technical problems that you have to deal with when switching to a Messaging architecture. For example, if you are looking for an answer on how to handle errors in various scenarios, or how to properly configure an Aggregator for the situations where some messages might not ever arrive for aggregation, or any other issue that goes beyond a basic understanding and configuration of a particular component to address "what else you can do?" types of problems, this would be the right place to find relevant examples.

  • async-gateway - Usage example of an asynchronous Gateway
  • dynamic-poller - Example shows usage of a Poller with a custom Trigger to change polling periods at runtime
  • async-gateway - Example shows usage of an Asynchronous Gateway
  • errorhandling - Demonstrates basic Error Handling capabilities of Spring Integration
  • file-processing - Sample demonstrates how to wire a message flow to process files either sequentially (maintain the order) or concurrently (no order).
  • mail-attachments - Demonstrates the processing of email attachments
  • monitoring The project used in the Spring Integration Management and Monitoring Webinar Also available on the SpringSourceDev YouTube Channel
  • multipart-http - Demonstrates the sending of HTTP multipart requests using Spring's RestTemplate and a Spring Integration Http Outbound Gateway
  • rest-http - This sample demonstrates how to send an HTTP request to a Spring Integration's HTTP service while utilizing Spring Integration's new HTTP Path usage. This sample also uses Spring Security for HTTP Basic authentication. With HTTP Path facility, the client program can send requests with URL Variables.
  • retry-and-more Provides samples showing the application of MessageHandler Advice Chains to endpoints - retry, circuit breaker, expression evaluating
  • splitter-aggregator-reaper A demonstration of implementing the Splitter and Aggregator Enterprise Integration Patterns (EIP) together. This sample also provides a concrete example of a message store reaper in action.
  • stored-procedures-derby Provides an example of the stored procedure Outbound Gateway using Apache Derby
  • stored-procedures-ms Provides an example of the stored procedure Outbound Gateway using Microsoft SQL Server
  • stored-procedures-oracle Provides an example of the stored procedure Outbound Gateway using ORACLE XE
  • stored-procedures-postgresql Provides an example of the stored procedure Outbound Gateway using PostgreSQL
  • tcp-async-bi-directional - Demonstrates the use of Collaborating Channel Adapters for arbitrary async messaging (not request/reply) between peers.
  • tcp-client-server-multiplex - Demonstrates the use of Collaborating Channel Adapters with multiple in-flight requests/responses over a single connection.
  • travel - More sophisticated example showing the retrieval of weather (SOAP Web Service) and traffic (HTTP Service) reports using real services
  • tx-synch Provides a sample demonstrating the use of transaction synchronization, renaming an input file to a different filename, depending on whether the transaction commits, or rolls back.

Advanced

This category targets advanced developers who are quite familiar with Spring Integration but are looking to address a specific custom need by extending the Spring Integration public API. For example, if you are looking for samples showing how to implement a custom Channel or Consumer (event-based or polling-based), or you are trying to figure out what is the most appropriate way to implement a custom BeanParser on top of the Spring Integration BeanParser hierarchy when implementing a custom namespace, this would be the right place to look. Here you can also find samples that will help you with adapter development. Spring Integration comes with an extensive library of adapters that allow you to connect remote systems with the Spring Integration messaging framework. However you might have a need to integrate with a system for which the core framework does not provide an adapter, so you have to implement your own. This category would include samples showing you how to implement various adapters.

  • advanced-testing-examples - Example test cases that show advanced techniques to test Spring Integration applications
  • dynamic-ftp - Demonstrates one technique for sending files to dynamic destinations.
  • dynamic-tcp-client - Demonstrates a technique for dynamically creating TCP clients.

Applications

This category targets developers and architects who have a good understanding of Message-Driven architecture and Enterprise Integration Patterns, and have an above average understanding of Spring and Spring integration and who are looking for samples that address a particular business problem. In other words, the emphasis of samples in this category is 'business use cases' and how they can be solved via a Messaging architecture and Spring Integration in particular. For example, if you are interested to see how a Loan Broker process or Travel Agent process could be implemented and automated via Spring Integration, this would be the right place to find these types of samples.

  • cafe - Emulates a simple operation of a coffee shop combining various Spring Integration adapters (Including Router and Splitter) see Appendix A of the reference documentation for more details. Implementations are provided for:
    • AMQP
    • JMS
    • In memory channels
  • cafe-scripted - Scripted implementation of the classic cafe sample application. Supports JavaScript, Groovy, Ruby, and Python.
  • loan-broker - Simulates a simple banking application (Uses Gateway, Chain, Header Enricher, Recipient List Router, Aggregator) see Appendix A of the reference documentation for more details
  • loanshark This extension to the loan broker sample shows how to exchange messages between Spring Integration applications (and other technologies) using UDP. file-split-ftp - Reads a file; splits into 3 based on contents; sends files over ftp; sends email with results.

Contributing

See the Spring Integration Contributor Guidelines for information about how to contribute to this repository.

Resources

For more information, please visit the Spring Integration website at: https://projects.spring.io/spring-integration/

More Repositories

1

spring-boot

Spring Boot
Java
71,736
star
2

spring-framework

Spring Framework
Java
54,504
star
3

spring-security

Spring Security
Java
8,263
star
4

spring-petclinic

A sample Spring-based application
CSS
7,090
star
5

spring-data-examples

Spring Data Example Projects
Java
5,026
star
6

spring-authorization-server

Spring Authorization Server
Java
4,660
star
7

spring-data-jpa

Simplifies the development of creating a JPA-based data access layer.
Java
2,853
star
8

spring-data-elasticsearch

Provide support to increase developer productivity in Java when using Elasticsearch. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
2,850
star
9

spring-loaded

Java agent that enables class reloading in a running JVM
Java
2,711
star
10

spring-batch

Spring Batch is a framework for writing batch applications using Java and Spring
Java
2,549
star
11

spring-retry

Java
2,071
star
12

spring-kafka

Provides Familiar Spring Abstractions for Apache Kafka
Java
2,067
star
13

spring-session

Spring Session
Java
1,823
star
14

spring-data-redis

Provides support to increase developer productivity in Java when using Redis, a key-value store. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
1,667
star
15

spring-data-mongodb

Provides support to increase developer productivity in Java when using MongoDB. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
1,566
star
16

spring-integration

Spring Integration provides an extension of the Spring programming model to support the well-known Enterprise Integration Patterns (EIP)
Java
1,486
star
17

spring-graphql

Spring Integration for GraphQL
Java
1,473
star
18

spring-statemachine

Spring Statemachine is a framework for application developers to use state machine concepts with Spring.
Java
1,463
star
19

spring-ai

An Application Framework for AI Engineering
Java
1,288
star
20

spring-security-samples

Java
1,134
star
21

spring-restdocs

Test-driven documentation for RESTful services
Java
1,126
star
22

spring-hateoas

Spring HATEOAS - Library to support implementing representations for hyper-text driven REST web services.
Java
1,021
star
23

spring-data-rest

Simplifies building hypermedia-driven REST web services on top of Spring Data repositories
Java
896
star
24

sts4

The next generation of tooling for Spring Boot, including support for Cloud Foundry manifest files, Concourse CI pipeline definitions, BOSH deployment manifests, and more... - Available for Eclipse, Visual Studio Code, and Theia
Java
829
star
25

spring-net

Spring Framework for .NET
C#
827
star
26

spring-cloud

Umbrella project for Spring Cloud
821
star
27

spring-data-neo4j

Provide support to increase developer productivity in Java when using Neo4j. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
806
star
28

spring-amqp

Spring AMQP - support for Spring programming model with AMQP, especially but not limited to RabbitMQ
Java
793
star
29

spring-data-commons

Spring Data Commons. Interfaces and code shared between the various datastore specific implementations.
Java
747
star
30

spring-data-relational

Spring Data Relational. Home of Spring Data JDBC and Spring Data R2DBC.
Java
724
star
31

spring-data-r2dbc

Provide support to increase developer productivity in Java when using Reactive Relational Database Connectivity. Uses familiar Spring concepts such as a DatabaseClient for core API usage and lightweight repository style data access.
708
star
32

spring-shell

Spring based shell
Java
693
star
33

spring-modulith

Modular applications with Spring Boot
Java
647
star
34

spring-amqp-samples

Samples for Spring AMQP
Java
587
star
35

spring-plugin

Java
428
star
36

spring-webflow-samples

CSS
407
star
37

spring-data-cassandra

Provides support to increase developer productivity in Java when using Apache Cassandra. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
370
star
38

spring-hateoas-examples

Collection of examples on how (and why) to build hypermedia-driven apps with Spring HATEOAS
Java
365
star
39

spring-ldap

Spring LDAP
Java
339
star
40

spring-webflow

Spring Web Flow
Java
319
star
41

spring-ws

Spring Web Services
Java
304
star
42

spring-flo

JavaScript angular based embeddable graphical component for pipeline/graph building and editing
TypeScript
296
star
43

spring-vault

Provides familiar Spring abstractions for HashiCorp Vault
Java
277
star
44

spring-integration-extensions

The Spring Integration Extensions project provides extension components for Spring Integration
Java
276
star
45

spring-data-couchbase

Provides support to increase developer productivity in Java when using Couchbase. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
272
star
46

spring-data-envers

Envers extension of the Spring Data JPA module
263
star
47

spring-batch-extensions

Spring Batch Extensions
Java
228
star
48

spring-integration-aws

Java
201
star
49

spring-security-kerberos

Spring Security Kerberos
Java
173
star
50

spring-pulsar

Spring Friendly Abstractions for Apache Pulsar
Java
168
star
51

spring-guice

Tools for using Spring in Guice and Guice in Spring
Java
168
star
52

gradle-plugins

Gradle plugins for use in building and publishing open-source Spring projects, e.g. Spring Framework, Spring Integration
Groovy
139
star
53

spring-ws-samples

Java
138
star
54

spring-data-keyvalue

Project to provide infrastructure to implement Spring Data repositories on top of key-value-based, in-memory data stores.
Java
127
star
55

spring-data-gemfire

Spring Data integration for Pivotal GemFire
Java
99
star
56

spring-data-build

Modules to centralize common resources and configuration for Spring Data Maven builds.
Shell
94
star
57

spring-data

Spring Data
85
star
58

spring-cli

A CLI focused on developer productivity
Java
75
star
59

spring-data-ldap

Repository abstraction for Spring LDAP
Java
65
star
60

spring-data-geode

Spring Data support for Apache Geode
Java
49
star
61

spring-aot-smoke-tests

Smoke tests for Spring's AOT and native support
Java
47
star
62

spring-session-data-mongodb

Spring Session for MongoDB
Java
47
star
63

spring-boot-data-geode

Spring Boot support for Apache Geode and VMware GemFire
Java
45
star
64

spring-data-dev-tools

A collection of tools to support Spring Data development.
Java
39
star
65

spring-session-bom

Spring Session Bill of Materials
Java
31
star
66

spring-restdocs-samples

JavaScript
27
star
67

spring-credhub

Spring abstractions for Cloud Foundry CredHub
Java
25
star
68

spring-test-data-geode

A Spring-based Test Framework supporting Unit and Integration testing for Spring Boot applications using Spring Data with either Apache Geode or VMware Tanzu GemFire
Java
22
star
69

spring-integration-splunk

Java
21
star
70

spring-session-data-geode

Spring Session support for Apache Geode and VMware Tanzu GemFire
Java
21
star
71

spring-session-data-mongodb-examples

Java
16
star
72

spring-data-bom

Spring Data Bill of Materials
16
star
73

eclipse-integration-tcserver

Eclipse Integration for vFabric tc Server
Java
14
star
74

security-advisories

Report a Spring CVE
12
star
75

spring-lifecycle-smoke-tests

Java
11
star
76

spring-integration-flow

Java
10
star
77

gh-pages

Shared gh-pages content for Spring projects
JavaScript
8
star
78

.github

7
star
79

spring-data-release

Command-line application to ship Spring Data releases
Java
5
star
80

spring-rewrite-commons

Java
3
star
81

spring-graphql-examples

3
star