Spring Integration概述与怎么使用详解

目录
  • 一、Spring Integration是什么?
  • 二、为什么要用Spring Integration?
  • 三、怎么使用
  • 总结

一、Spring Integration是什么?

spring-integration是一个功能强大的EIP(Enterprise Integration Patterns),即企业集成模式。多个系统或者功能,少不了消息交互 ,Spring intergration的出现解决了系统与系统之间的功能之间消息交互的问题。

二、为什么要用Spring Integration?

目标和原则

Spring集成的动机是以下目标:

  • 为实现复杂的企业集成解决方案提供一个简单的模型。
  • 在基于Spring的应用程序中促进异步、消息驱动的行为。

促进对现有Spring用户的直观、增量采用。

Spring集成遵循以下原则:

  • 为了模块化和可测试性,组件应该是松散耦合的。
  • 框架应该执行业务逻辑和集成逻辑之间的关注点分离。
  • 扩展点在本质上应该是抽象的(但在定义良好的边界内),以促进重用和可移植性。

三、怎么使用

我们首先看一下它的核心api

1. Message

Message,用来传输消息体的对象,所有的流程都围绕着Message运转。Message分为两部分,header和payload。header是头部信息通常用来保存如Id,时间戳,相关Id和返回地址等信息。payload是用来装载数据的,它可以携带的任何类型对象。

2.MessageChannel

消息通道表示管道和过滤器体系结构的“管道”。生产者向通道发送消息,消费者从通道接收消息。因此,消息通道对消息传递组件进行了解耦,并提供了一个方便的点来拦截和监视消息。

(1)MessageChannel顶级接口

public interface MessageChannel {
boolean send(Message message);
boolean send(Message message, long timeout);
}

发送消息时,返回值是true消息发送成功。如果发送呼叫超时或被中断,它将返回false

(2)PollableChannel,MessageChannel的子接口

public interface PollableChannel extends MessageChannel {
    Message<?> receive();
    Message<?> receive(long timeout);
}

此消息通道会缓存消息(可轮询),与send方法一样,当接收到消息时,如果发生超时或中断,则返回值为null。

(3)SubscribableChannel,MessageChannel的子接口

public interface SubscribableChannel extends MessageChannel {
    boolean subscribe(MessageHandler handler);
    boolean unsubscribe(MessageHandler handler);
}

因为SubscribableChannel基本接口是由将消息直接发送到其订阅的频道实施MessageHandler的实例,因此消息通道不会缓存消息。

3.Message Endpoint

(1)Message Router

路由器,用来管理一个消息应该被发送到哪个channel中。相当于JAVA里面的switch case语句吧。判断条件很多,可是使用header里面的参数具体值(比如header里面有个定义为testRouter的参数,数值为A,那么消息经过路由会发送到判断为A的通道内,后面使用中再详细讲解)

(2)Message Filter

过滤器,用来判断一个消息是否应该被传输。

(3)Service Activator

服务激活器是用于将服务实例连接到消息传递系统的通用端点。必须配置输入消息通道,并且,如果要调用的服务方法能够返回值,则还可以提供输出消息通道。

(4)Message Transformer

消息转换器负责转换消息的内容或结构并返回修改后的消息。可能最常见的一种转换器是将消息的有效负载从一种格式转换为另一种格式(例如,从XML转换为java.lang.String)的一种。同样,转换器可以添加,删除或修改消息的标头值。

(5) Channel Adapter

通道适配器是将消息通道连接到其他系统或传输的终结点。通道适配器可以是入站的或出站的。通常,通道适配器在消息与从其他系统接收或发送到其他系统的任何对象或资源(文件,HTTP请求,JMS消息等)之间进行一些映射。根据传输情况,通道适配器还可以填充或提取消息头值。

入站通道适配器端点将源系统连接到MessageChannel

出站通道适配器端点将a连接MessageChannel到目标系统。

总结

到此这篇关于Spring Integration概述与怎么使用的文章就介绍到这了,更多相关Spring Integration使用内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 源码解读Spring-Integration执行过程

    一,前言 Spring-Integration基于Spring,在应用程序中启用了轻量级消息传递,并支持通过声明式适配器与外部系统集成.这一段官网的介绍,概况了整个Integration的用途.个人感觉消息传递是真正的重点. 如上图所示,典型的生产者-消费者模式,中间通过一个特定的通道进行数据传输,说到这,是不是隐隐感觉到queue的存在.确实事实上这个所谓的通道默认就是用的 blockingqueue. Spring-Integration网上的资料是真少,再加上源码分析的是更少.关于Spri

  • Spring Integration概述与怎么使用详解

    目录 一.Spring Integration是什么? 二.为什么要用Spring Integration? 三.怎么使用 总结 一.Spring Integration是什么? spring-integration是一个功能强大的EIP(Enterprise Integration Patterns),即企业集成模式.多个系统或者功能,少不了消息交互 ,Spring intergration的出现解决了系统与系统之间的功能之间消息交互的问题. 二.为什么要用Spring Integration

  • Spring MVC 拦截器 interceptor 用法详解

    Spring MVC-拦截器 今天就是把有关拦截器的知识做一个总结. 1.拦截器概述 1.1 什么是拦截器? Spring MVC中的拦截器(Interceptor)类似于Servlet中的过滤器(Filter),它主要用于拦截用户请求并作相应的处理.例如通过拦截器可以进行权限验证.记录请求信息的日志.判断用户是否登录等. 要使用Spring MVC中的拦截器,就需要对拦截器类进行定义和配置.通常拦截器类可以通过两种方式来定义. 1.通过实现HandlerInterceptor接口,或继承Han

  • spring boot的maven配置依赖详解

    本文介绍了spring boot的maven配置依赖详解,分享给大家,具体如下: 我们通过引用spring-boot-starter-parent,添加spring-boot-starter-web 可以实现web项目的功能,当然不使用spring-boot-start-web,通过自己添加的依赖包也可以实现,但是需要一个个添加,费时费力,而且可能产生版本依赖冲突.我们来看下springboot的依赖配置: 利用pom的继承,一处声明,处处使用.在最顶级的spring-boot-dependen

  • JSP Spring配置文件中传值的实例详解

    JSP Spring配置文件中传值的实例详解 通过spring提供方法,在配置文件中取传值 调用get方法  targetObject :指定调用的对象       propertyPath:指定调用那个getter方法 例1: public class Test1 { private String name = "nihao"; public String getName() { return name; } } Xml代码 <bean id="t1" cl

  • Spring quartz Job依赖注入使用详解

    Spring quartz Job依赖注入使用详解 一.问题描述: 使用Spring整合quartz实现动态任务时,想在job定时任务中使用某个service时,直接通过加注解@Component.@Autowired是不能注入的,获取的对象为Null.如下面的代码: @Component @PersistJobDataAfterExecution @DisallowConcurrentExecution public class TicketSalePriceLessThanLowestPri

  • spring Boot与Mybatis整合优化详解

    SpringBoot官方文档http://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/ 关于spring-boot与mybatis整合优化方面的介绍,就是Mybatis-Spring-boot-starter的介绍: 1.取消spring-mybatis.xml配置 ①自动检测已存在的Datasource 之前,需要在spring-mybatis.xml中配置datasource的Bean,现在只需要在applicat

  • spring boot + jpa + kotlin入门实例详解

    spring boot +jpa的文章网络上已经有不少,这里主要补充一下用kotlin来做. kotlin里面的data class来创建entity可以帮助我们减少不少的代码,比如现在这个User的Entity,这是Java版本的: @Entity public class User { @Id @GeneratedValue(strategy = GenerationType.AUTO) private long id; private String firstName; private S

  • Spring Quartz2 动态任务的实例详解

    Spring Quartz2 动态任务的实例详解 此处使用的是Quartz中SimpleScheduleBuilder类,非CronScheduleBuilder,CronScheduleBuilder是Cron表达式的.具体请自行百度. 实现代码: /** * 新增任务 * @param scheduleJob * @throws Exception */ @Override @SuppressWarnings("unchecked") public void addJobSimpl

  • Spring学习笔记1之IOC详解尽量使用注解以及java代码

    在实战中学习Spring,本系列的最终目的是完成一个实现用户注册登录功能的项目. 预想的基本流程如下: 1.用户网站注册,填写用户名.密码.email.手机号信息,后台存入数据库后返回ok.(学习IOC,mybatis,SpringMVC的基础知识,表单数据验证,文件上传等) 2.服务器异步发送邮件给注册用户.(学习消息队列) 3.用户登录.(学习缓存.Spring Security) 4.其他. 边学习边总结,不定时更新.项目环境为Intellij + Spring4. 一.准备工作. 1.m

  • spring boot(四)之thymeleaf使用详解

    在上篇文章springboot(二):web综合开发中简单介绍了一下thymeleaf,这篇文章将更加全面详细的介绍thymeleaf的使用.thymeleaf 是新一代的模板引擎,在spring4.0中推荐使用thymeleaf来做前端模版引擎. thymeleaf介绍 简单说, Thymeleaf 是一个跟 Velocity.FreeMarker 类似的模板引擎,它可以完全替代 JSP .相较与其他的模板引擎,它有如下三个极吸引人的特点: 1.Thymeleaf 在有网络和无网络的环境下皆可

随机推荐