A curated list of awesome integration patterns, software and resources. Inspired by awesome-... stuff.
API Management solutions.
- Anypoint Platform - Combines API management and integration capabilities in a single platform from Mulesoft.
- Akana API Management Platform - Accelerate digital transformation. Manage the full API lifecycle. Deploy across multiple clouds. And ensure compliance.
- Amazon API Management - API management strategies allow you to monitor and manage APIs in a secure and scalable way.
- Amplify API Management Platform - An open platform for API management from Axway.
- Apigee - API Management solution from Google.
- Azure API Management - A hybrid, multicloud management platform for APIs across all environments.
- DigitMarket API Manager - A complete package to help manage your APIs and make them into tools that propel your business forward by Torry Harris.
- Gravitee.io API Management - Flexible, lightweight and blazing-fast Open Source solution.
- IBM API Connect - A complete, intuitive and scalable API platform that lets you create, expose, manage and monetize APIs across clouds.
- Kong Enterprise - The service connectivity platform.
- Layer7 API Management - Continuous API Management from Broadcom.
- Red Hat 3scale API Management - Cloud-native development made simpler and more flexible.
- Sensedia API Management - Full life cycle API management platform.
- TIBCO Cloud Mashery - The cloud-native API platform you can deploy anywhere, and manage APIs from everywhere.
- Tyk API Management - Connect, build and control.
- webMethods API - Software AG offerings for full life cycle API management are the webMethods API management. platform (for on-premises deployment) and the webMethods.io API (for the cloud).
- WSO2 API Manager - Fully open-source API management platform.
API design, documentation and life-cycle automation tools.
- Swagger Editor - Design, describe, and document your API on the first open source editor fully dedicated to OpenAPI-based APIs.
API Gateways.
- Apache APISIX - Dynamic, real-time, high-performance API gateway.
- Gloo Edge - An Envoy Proxy-based API Gateway.
- Goku API Gateway - Golang-based microservice gateway that enables high-performance dynamic routing,service orchestration, multi-tenancy management, API access control, etc.
- Kong API Gateway - Cloud-native, platform-agnostic, scalable API Gateway distinguished for its high performance and extensibility via plugins.
- KrakenD API Gateway - Ultra-High performance API Gateway with middlewares.
- Ocelot - .NET API Gateway.
- Spring Cloud Gateway - API Gateway built on top of the Spring Ecosystem, including: Spring 5, Spring Boot 2 and Project Reactor.
- Tyk API Gateway - An open source Enterprise API Gateway, supporting REST, GraphQL, TCP and gRPC protocols.
API testing tools.
- Apache JMeter - An open source java based load testing tool.
- curl - Command line tool and library for transferring data with URLs.
- HTTPie - Command line HTTP client, far more dev-friendly than curl.
- Insomnia - Cross-platform HTTP and GraphQL Client.
- Karate - Open-source tool to combine API test-automation, mocks, performance-testing and even UI automation into a single, unified framework.
- Postman - A tool to make HTTP requests, generate mock servers and make API documentation.
- SoapUI - An open-source web service testing application for SOAP and REST.
Business Rules Engines and Business Rules Management Systems.
- Drools - Open source tool with full runtime support for Decision Model and Notation (DMN) models at Conformance level 3 and an Eclipse IDE plugin for core development.
- Easy Rules - A simple Java rules engine.
- NxBRE - Open-source rule engine for the .NET platform.
- OpenL Tablets - An open source business rules engine (BRE, BRMS) and decision management system.
Business Process Management solutions.
- Appian BPM Suite - Platform combines low-code development with process management to allow both IT and citizen developers to construct process-centric and case-centric applications.
- IBM Business Automation Workflow - A comprehensive business process management platform.
- Oracle BPM Suite - An integrated environment for developing, administering, and using business applications centered around business processes.
- Pega Platform - A combined business process management and robotic process automation (RPA) platform with advanced workforce analytics from Pegasystems.
- SAP Process Orchestration - A business process management offering and application infrastructure.
- TIBCO BPM Enterprise - A business process management platform with capabilities for process automation, process documentation, human capital management, process patterns, and predictive operations analytics.
Data Mapping solutions.
- AltasMap - Data mapping solution with interactive web based user interface, that simplifies configuring integrations between Java, XML, CSV and JSON data sources.
Enterprise service bus solutions.
- Anypoint Platform - Combines API management and integration capabilities in a single platform from Mulesoft.
- Apache ServiceMix - A flexible, open-source integration container that unifies the features and functionality of Apache ActiveMQ, Camel, CXF, and Karaf.
- ArcESB - Synchronize data across applications, seamlessly integrate with partners, or make data publicly accessible.
- IBM App Connect - Connect applications together, regardless of the message formats or protocols that they support. Formerly known as IBM Integration Bus.
- NServiceBus - The most developer-friendly service bus for .NET.
- Oracle Service Bus - Transforms complex and brittle architectures into agile integration networks by connecting, virtualizing, and managing interactions between services and applications.
- Oracle SOA Suite - Enables system developers to set up and manage services and to orchestrate them into composite applications and business processes.
- Red Hat Fuse - Distributed, cloud-native integration platform.
- Software AG webMethods Integration Server - Integrate anything faster.
- TIBCO BusinessWorks - Implement enterprise patterns for hybrid integrations.
- UltraESB - The only ESB that supports Zero-Copy proxying for extreme levels of performance utilizing Direct Memory Access (DMA) and the sendfile system call along with Non-Blocking IO.
- WSO2 Enterprise Integrator - An API-centric, cloud-native, and distributed integration platform.
ETL/ELT and data integration tools.
- Apache NiFi - Apache NiFi is an integrated data logistics platform for automating the movement of data between disparate systems.
- CloverETL - A data integration software suite for data migration and data warehousing, and for feeding data into business intelligence and reporting applications.
- IBM DataStage - A data integration platform that helps businesses understand, cleanse, transform, and deliver trusted information.
- Informatica PowerCenter - Delivers enterprise data integration and management software powering analytics for big data and cloud.
- Microsoft SSIS - SQL Server Integration Services is a platform for building enterprise-level data integration and data transformations solutions.
- Oracle Data Integrator - A comprehensive data integration platform that covers all data integration requirements, including batch loads, integration processes, and SOA-enabled data services.
- Pentaho Data Integration - Enables users to ingest, blend, cleanse, and prepare diverse data from any source with visual tools to eliminate coding and complexity.
- SAS Data Management - Helps transform, integrate, govern, and secure data while improving its overall quality and reliability.
- Stitch - A simple, powerful ETL service for businesses of all sizes, up to and including the enterprise. Running on a scalable, fault-tolerant cloud platform, Stitch integrates data from dozens of different sources.
- Talend Data Integration - Bring data together from multiple sources to power all your business decisions.
Integration frameworks based on known Enterprise Integration Patterns.
- Apache Camel - Glues together different transport APIs via Enterprise Integration Patterns.
- Ballerina - An open-source programming language that makes it easier to use, combine, and create network services.
- Spring Integration - Extends the Spring programming model to support the well-known Enterprise Integration Patterns.
Integration Platform as a Service.
- Anypoint Platform - Combines API management and integration capabilities in a single platform from Mulesoft.
- Dell Boomi AtomSphere - Connect everyone to everything with the cloud-native, unified, open, intelligent platform.
- Jitterbit Harmony - Integrates thousands of applications with pre-built templates and workflows to automate your business processes.
- IBM Cloud Integration - AI-powered approach to integration.
- Informatica Intelligent Cloud Services - Multiple cloud data management products designed to accelerate productivity and improve speed and scale.
- OpenText Alloy - Enterprise data management, organizations move beyond basic integration and turn data into insights and action. Formerly known as Liaison ALLOY Platform.
- Oracle Integration Cloud Service - Accelerates time to go live with pre-built connectivity to any SaaS or on-premises application.
- SnapLogic Intelligent Integration Platform - Connect your application and data landscape.
- Software AG webMethods Hybrid Integration Platform - One application integration platform integrates it all.
- TIBCO Cloud Integration - Empower everyone to integrate anything with API-led and event-driven integration.
- Workato - A single platform for integration & workflow automation across your organization.
Managed file transfer (MFT) solutions.
- ArcESB Managed File Transfer - All-in-One Enterprise-Class MFT.
- Axway Managed File Transfer - Make file transfer services easy to use.
- IBM Sterling Secure File Transfer - Move over 1 million files per day with a fast and scalable file transfer platform.
- Oracle Managed File Transfer - Enables secure file exchange and management.
Master Data Management solutions.
- IBM InfoSphere Master Data Management - Comprehensive master data management.
- Informatica Multidomain MDM - All-in-one master data management.
- Oracle Enterprise Data Management - Adapt and respond to change faster and more effectively by managing your master data.
- SAP Master Data Governance - Improve the quality and consistency of information across your organization by consolidating and centrally governing the master data lifecycle.
- SAS MDM - Provides a single, accurate and unified view of corporate data, integrating information from various data sources into one master record.
- Software AG OneData for MDM - Provides “one version of the truth” when it comes to data, ensuring that only reliable, accurate and approved information is flowing through your systems, processes and applications.
- Teradata MDM - Drives significant ROI using consistent reference data to establish an accurate analytical data foundation.
- TIBCO EBX - A single solution to govern, manage, and consume all shared data assets.
Message brokers.
- Apache ActiveMQ - Message broker that implements JMS and converts synchronous to asynchronous communication.
- Apache Kafka - High-throughput distributed messaging system.
- Apache Pulsar - Distributed pub/sub-messaging system.
- Apache RocketMQ - Fast, reliable, and scalable distributed messaging platform.
- Apache Qpid - Apache Qpid makes messaging tools that speak AMQP and support many languages and platforms.
- Eclipse Mosquitto - An lightweight open source message broker that implements the MQTT protocol.
- IBM MQ - Enterprise-grade messaging capabilities that skillfully and safely move information between applications.
- KubeMQ - A Kubernetes Message Queue Broker Enterprise-grade message broker and message queue, scalable, high available and secured.
- NATS - Lightweight, high performance messaging system for microservices, IoT, and cloud native systems.
- Oracle AQ - Oracle Advanced Queuing (AQ) provides enterprise message functionality across many industries and is widely used within the database itself.
- RabbitMQ - An open-source message-broker that originally implemented the Advanced Message Queuing Protocol (AMQP).
- Red Hat AMQ - Red Hat AMQ-based on open source communities like Apache ActiveMQ and Apache Kafka.
- TIBCO Enterprise Message Service - TIBCO EMS is standards-based Java™ Message Service (JMS) implementation allows any application that supports JMS, whether home grown or third-party, to quickly and easily exchange messages.
Cloud messaging as a service (MaaS).
- Amazon MQ - Fully managed message broker service for Apache ActiveMQ and RabbitMQ.
- Amazon MSK - Amazon Managed Streaming for Apache Kafka.
- Amazon SQS - Amazon Simple Queue Service.
- Amazon SNS - Amazon Simple Notification Service. Pub/sub functionality provides topics for high-throughput, push-based, many-to-many messaging between distributed systems, microservices, and event-driven serverless applications.
- Alibaba Cloud Message Queue for Apache Kafka - Fully-managed Apache Kafka service from Alibaba Cloud.
- Alibaba Cloud Message Queue for RabbitMQ - A distributed, fully managed, and professional messaging service that features high throughput, low latency, and high scalability.
- Alibaba Cloud Message Service - A distributed message queuing and notification service that supports concurrent operations to facilitate message transfer between applications and decoupled systems.
- AlibabaMQ for Apache RocketMQ - A distributed message queue service that supports reliable message-based asynchronous communication among microservices, distributed systems, and serverless applications.
- Anypoint MQ - Enterprise-class cloud messaging, fully integrated with Anypoint Platform.
- Azure Service Bus - Reliable cloud messaging as a service (MaaS) and simple hybrid integration.
- CloudAMQP - RabbitMQ as a Service.
- Google Cloud Pub/Sub - Messaging and ingestion for event-driven systems and streaming analytics.
- IBM MQ on Cloud - Easily move data between enterprise applications, systems and services.
- IronMQ - Elastic message queue created specifically with the cloud in mind.
- Solace PubSub+ Cloud - A complete event streaming, management and insights platform.
- Yandex Message Queue - Compatibility with the Amazon SQS HTTP API.
- Yandex Managed Service for Apache Kafka - Managed Apache Kafka service.
Robotic Process Automation (RPA) solutions.
- Automation Anywhere - Intelligent Automation Ecosystem.
- Blue Prism - Intelligent automation - business-developed and no-code automation RPA platform.
- UiPath - Automattion repetitive digital tasks normally performed by people.
- WorkFusion - Automation Platform for the Enterprise.
Any self-service and citizen integrator tools.
- IFTTT - Allows creating chains of conditional statements between web services in order to make the web work for you and boost your productivity.
- Oracle Self-Service Integration - Automates tasks between cloud applications.
- Zapier - Automation tool that allows you to connect hundreds of web services and create automations between the processes.
Workflow and orchestration engines.
- Activiti - A lightweight and java-centric open-source BPMN engine.
- Apache Airflow - A platform to programmatically author, schedule, and monitor workflows.
- Argo Workflows - An open source container-native workflow engine for orchestrating parallel jobs on Kubernetes.
- Azkaban - A distributed Workflow Manager, implemented at LinkedIn to solve the problem of Hadoop job dependencies.
- Bonita - BPMN engine that comes with an optional development environment, a designer, an optional user interface and administrative tools.
- Cadence - Fault-Tolerant Stateful Code Platform.
- Camunda - An open-source workflow and decision automation platform.
- Conductor - Netflix Conductor is an orchestration engine that runs in the cloud.
- Elsa Core - A workflows library that enables workflow execution in any .NET Core application.
- Flowable - Provides a core set of open source business process engines that are compact and highly efficient.
- jBPM - A toolkit for building business applications to help automate business processes and decisions.
- StackStorm - Robust Automation Engine providing Sensors, Triggers, Rules, Workflows, and Actions. StackStorm is how you “glue” your applications together.
Some useful specifications, patterns, articles and documentation.
- AsyncAPI - The AsyncAPI specification settles the base for a greater and better tooling ecosystem for Event-Driven Architectures (EDA).
- GraphQL - A query language for APIs and a runtime for fulfilling those queries with your existing data.
- OpenAPI (ex.Swagger) - Defines a standard, language-agnostic interface to RESTful APIs which allows both humans and computers to discover and understand the capabilities of the service without access to source code, documentation, or through network traffic inspection.
- RAML - RESTful API Modeling Language.
- WSDL - XML-based interface description language for SOAP based services.
- Enterprise Integration Using REST - Discusses the constraints and flexibility that you have with nonpublic APIs, and lessons learned from doing large scale RESTful integration across multiple teams.
- Richardson Maturity Model - Explained by Martin Fowler, originally presented by Leonard Richardson.
- JCA - Defines a standard architecture for Jakarta EE application components to connect to Enterprise Information Systems. Formerly Java EE Connector Architecture and J2EE Connector Architecture.
- Kafka Connect - A tool for scalably and reliably streaming data between Apache Kafka and other systems.
- Apache Avro - Data serialization system.
- BSON - Short for Binary JSON, is a binary-encoded serialization of JSON-like documents.
- CSV - A comma-separated values (CSV) file is a delimited text file that uses a comma to separate values.
- JSON - The JavaScript Object Notation (JSON) Data Interchange Format.
- NDJSON - A standard for delimiting JSON in stream protocols.
- Protocol Buffers - A language-neutral, platform-neutral extensible mechanism for serializing structured data.
- XML - Extensible Markup Language (XML).
- YAML - YAML is a human friendly data serialization standard for all programming languages.
Patterns from a book by Gregor Hohpe and Bobby Woolf.
- Aggregator - How do we combine the results of individual, but related messages so that they can be processed as a whole?
- Canonical Data Model - How can you minimize dependencies when integrating applications that use different data formats?
- Channel Adapter - How can you connect an application to the messaging system so that it can send and receive messages?
- Channel Purger - How can you keep 'left-over' messages on a channel from disturbing tests or running systems?
- Claim Check - How can we reduce the data volume of message sent across the system without sacrificing information content?
- Command Message - How can messaging be used to invoke a procedure in another application?
- Competing Consumers - How can a messaging client process multiple messages concurrently?
- Composed Message Processor - How can you maintain the overall message flow when processing a message consisting of multiple elements, each of which may require different processing?
- Content Enricher - How do we communicate with another system if the message originator does not have all the required data items available?
- Content Filter - How do you simplify dealing with a large message, when you are interested only in a few data items?
- Content-Based Router - How do we handle a situation where the implementation of a single logical function (e.g., inventory check) is spread across multiple physical systems?
- Control Bus - How can we effectively administer a messaging system that is distributed across multiple platforms and a wide geographic area?
- Correlation Identifier - How does a requestor that has received a reply know which request this is the reply for?
- Datatype Channel - How can the application send a data item such that the receiver will know how to process it?
- Dead Letter Channel - What will the messaging system do with a message it cannot deliver?
- Detour - How can you route a message through intermediate steps to perform validation, testing or debugging functions?
- Document Message - How can messaging be used to transfer data between applications?
- Durable Subscriber - How can a subscriber avoid missing messages while it is not listening for them?
- Dynamic Router - How can you avoid the dependency of the router on all possible destinations while maintaining its efficiency?
- Envelope Wrapper - How can existing systems participate in a messaging exchange that places specific requirements on the message format, such as message header fields or encryption?
- Event Message - How can messaging be used to transmit events from one application to another?
- Event-Driven Consumer - How can an application automatically consume messages as they become available?
- Format Indicator - How can a message`s data format be designed to allow for possible future changes?
- Guaranteed Delivery - How can the sender make sure that a message will be delivered, even if the messaging system fails?
- Idempotent Receiver - How can a message receiver deal with duplicate messages?
- Invalid Message Channel - How can a messaging receiver gracefully handle receiving a message that makes no sense?
- Message - How can two applications connected by a message channel exchange a piece of information?
- Message Dispatcher - How can multiple consumers on a single channel coordinate their message processing?
- Message Expiration - How can a sender indicate when a message should be considered stale and thus shouldn`t be processed?
- Message Translator - How can systems using different data formats communicate with each other using messaging?
- Message Broker - How can you decouple the destination of a message from the sender and maintain central control over the flow of messages?
- Message Bus - What is an architecture that enables separate applications to work together, but in a decoupled fashion such that applications can be easily added or removed without affecting the others?
- Message Channel - How does one application communicate with another using messaging?
- Message Endpoint - How does an application connect to a messaging channel to send and receive messages?
- Message Filter - How can a component avoid receiving uninteresting messages?
- Message History - How can we effectively analyze and debug the flow of messages in a loosely coupled system?
- Message Router - How can you decouple individual processing steps so that messages can be passed to different filters depending on a set of conditions?
- Message Sequence - How can messaging transmit an arbitrarily large amount of data?
- Message Store - How can we report against message information without disturbing the loosely coupled and transient nature of a messaging system?
- Messaging Bridge - How can multiple messaging systems be connected so that messages available on one are also available on the others?
- Messaging Gateway - How do you encapsulate access to the messaging system from the rest of the application?
- Messaging Mapper - How do you move data between domain objects and the messaging infrastructure while keeping the two independent of each other?
- Normalizer - How do you process messages that are semantically equivalent, but arrive in a different format?
- Pipes and Filters - How can we perform complex processing on a message while maintaining independence and flexibility?
- Point-to-Point Channel - How can the caller be sure that exactly one receiver will receive the document or perform the call?
- Polling Consumer - How can an application consume a message when the application is ready?
- Process Manager - How do we route a message through multiple processing steps when the required steps may not be known at design-time and may not be sequential?
- Publish-Subscribe Channel - How can the sender broadcast an event to all interested receivers?
- Recipient List - How do we route a message to a list of dynamically specified recipients?
- Request-Reply - When an application sends a message, how can it get a response from the receiver?
- Resequencer - How can we get a stream of related but out-of-sequence messages back into the correct order?
- Return Address - How does a replier know where to send the reply?
- Routing Slip - How do we route a message consecutively through a series of processing steps when the sequence of steps is not known at design-time and may vary for each message?
- Scatter-Gather - How do you maintain the overall message flow when a message needs to be sent to multiple recipients, each of which may send a reply?
- Selective Consumer - How can a message consumer select which messages it wishes to receive?
- Service Activator - How can an application design a service to be invoked both via various messaging technologies and via non-messaging techniques?
- Smart Proxy - How can you track messages on a service that publishes reply messages to the Return Address specified by the requestor?
- Splitter - How can we process a message if it contains multiple elements, each of which may have to be processed in a different way?
- Test Message - What happens, though, if a component is actively processing messages, but garbles outgoing messages due to an internal fault?
- Transactional Client - How can a client control its transactions with the messaging system?
- Wire Tap - How do you inspect messages that travel on a point-to-point channel?
- API Management
- BPM
- ETL
- iPaaS
- RPA
- AMQP 0-9-1 - Advanced Message Queuing Protocol (AMQP) Version 0-9-1.
- AMQP 1.0 - Advanced Message Queuing Protocol (AMQP) Version 1.0.
- HTTP - The Hypertext Transfer Protocol (HTTP) is an application layer protocol for distributed, collaborative, hypermedia information systems.
- MQTT - The Message Queuing Telemetry Transport (MQTT) is a lightweight, publish-subscribe network protocol that transports messages between devices.
- SOAP - Simple Object Access Protocol is XML-based messaging protocol.
- STOMP - Simple (or Streaming) Text Orientated Messaging Protocol.
- JDBC - Java Database Connectivity (JDBC) API provides universal data access from the Java programming language.
- JMS - Java Message Service (JMS) API.
- ODBC - Open Database Connectivity (ODBC) is a widely accepted application programming interface (API) for database access.
- JSON Schema - A powerful tool for validating the structure of JSON data.
- XML Schema - Offers facilities for describing the structure and constraining the contents of XML documents.
- Fork it!
- Create your branch:
git checkout -b my-new-branch
- Commit your changes:
git commit -am 'fix stuff'
- Push to the branch:
git push origin my-new-branch
- Submit a pull request