第12章 使用Spring远程处理
12.4 在Spring中使用JMS
使用面向消息的中间件(通常成为MQ服务器)是另一种支持应用程序间通信的流行方法。消息队列(MQ)服务器的主要优点在于为应用程序集成提供了异步和松耦合的方式。在Java中,JMS是连接到MQ服务器以发送或接收消息的标准。MQ服务器维护应用程序可以连接并发送和接受消息的队列即主题列表。
- 队列
队列用于支持点对点消息交换模型。当一名生产者向队列发送消息时,MQ服务器会将消息保留在队列中,并在消费者下次连接时将消息传递给一名消费者(且只能传递给一名消费者)。 - 主题
主题用于支持发布-订阅模型。任何数量的客户端都可以订阅主题中的消息。当某条消息到达主题时,MQ服务器会将其发送给订阅了该消息的所有客户端。
从Spring5开始,不再支持JMS1.1。
TODO:
示例使用的是 HornetQ,应该换成更流行的消息队列。
另外,需要深入学习一种消息队列,以及Spring与消息队列的结合使用,具体学习哪种,可以从Spring Boot的starter里寻找。
12.5 Spring Boot Artemis启动器
JmsTemplate
bean不仅可以发送消息,还可以接收消息,但这是同步完成的,意味着JmsTemplate会被阻塞。这就是使用显式配置的JmsListenerContainerFactory
bean来创建DefaultMessageListenerContainer
的原因——能够以最高的连接效率异步的使用消息。
12.6 在Spring中使用RESTful-WS
12.6.1 RESTful Web服务介绍
RESTful-WS
中的REST
是REpresentational State Transfer
的缩写,是一种架构样式。REST定义了一组架构约束,它们共同描述了一个访问资源的统一接口。这个统一接口通过不同的表达形式来识别和操作资源。为了识别资源,应该通过统一资源标识符(URI)访问一条信息。
12.7 配置Castor XML
Spring自带的Jackson有支持XML的方法,不知道为什么不使用Jackson?
12.7.1 实现SingerController
@ResponseBody
注解指示方法的返回值应该直接写入HTTP响应流,而不是与视图匹配。
使用@RequestBody
对入参进行注解,指示Spring自动将HTTP请求体内的内容绑定到入参对象。该转换通过org.springframework.http.converter.HttpMessageConverter
接口来完成。
12.7.2 配置Spring Web应用程序
Spring Web应用程序遵循Front Controller设计模式
,其中所有请求都由单个控制器接收,然后分派给相应的处理程序(控制器类)。中央调度程序是org.springframework.web.servlet.DispatcherServlet
的一个实例,由org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer
类进行注册,需要对该类进行扩展以替换web.xml配置。
12.7.4 使用RestTemplate
访问RESTful-WS
可以使用RestTemplate
类访问RESTful Web服务。
TODO 深入学习
org.springframework.web.client.RestTemplate
12.7.5 使用Spring Security来保护RESTful-WS
org.springframework.http.client.HttpComponentsClientHttpRequestFactory
是Spring对Apache HttpComponents HttpClient
库提供的支持。
TODO 深入学习
Spring Security
12.8 使用Spring Boot开发RESTful-WS
12.9 在Spring中使用AMQP
远程处理可以通过使用以高级消息队列协议(AMQP)作为传输协议的远程过程调用(RPC)通信来完成。AMQP是实现面向消息中间件(MOM)的开放标准协议。
JMS应用程序适用于任何操作系统环境,但仅支持Java平台。AMQP标准可用于开发可轻松同行的多种语言的应用程序。
与使用JMS相似,AMQP也是用消息代理来交换消息。Spring本身没有在核心框架中提供远程处理功能,而是提供了Spring AMQP项目来处理。
Spring AMQP项目由两部分组成:spring-amqp
是基本抽象,spring-rabbit
是RabbitMQ实现。
虽然配置相似,但JMS和AMQP是两种完全不同的传输协议。