Spring Boot 2.x实战97 - 事件驱动6 - RSocket

本文详细介绍了Spring Boot 2.x中RSocket事件驱动的应用,包括新建Server和Client应用,Spring Boot的自动配置,以及各种交互模型的示例,如request/response、request/stream、fire-and-forget和channel。文中还提供了配置RSocket Server连接MongoDB,客户端调用RSocket Server的实现方式,并进行了验证。

5.RSocket

RSocket是一个使用在字节流传输(TCP/Websocket)之上的二进制点对点通讯协议;它主要用在分布式应用上,用来替换如HTTP这种通讯协议。

RSocket提供四种交互模型:

  • request/response:请求返回一条流数据(Mono<T>);
  • request/stream:请求返回多条流数据(Flux<T>);
  • fire-and-forget:请求不返回数据(Mono<Void>);
  • channel:双向流数据通讯(Flux<R> method(Publisher<T> input))。
5.1 新建应用
5.1.1 Server

新建应用,信息如下:

Group:top.wisely

Artifact:rsocket-server

Dependencies:RSocketSpring Data Reactive MongoDBLombok

build.gradle文件中的依赖如下:

dependencies {
   
   
	implementation 'org.springframework.boot:spring-boot-starter-rsocket'
	implementation 'org.springframework.boot:spring-boot-starter-data-mongodb-reactive'
	compileOnly 'org.projectlombok:lombok'
	annotationProcessor 'org.projectlombok:lombok'
  //...
	}
}
5.1.2 Client

新建应用,信息如下:

Group:top.wisely

Artifact:rsocket-client

Dependencies:RSocketSpring Reactive WebLombok

build.gradle文件中的依赖如下:

dependencies {
   
   
	implementation 'org.springframework.boot:spring-boot-starter-webflux'
	implementation 'org.springframework.boot:spring-boot-starter-rsocket'
	compileOnly 'org.projectlombok:lombok'
	annotationProcessor 'org.projectlombok:lombok'
  //...
	}
}
5.2 Spring Boot的自动配置

服务端的配置有:

  • RSocketServerAutoConfiguration:通过RSocketProperties使用spring.rsocket.server.*配置RSocket Server;
  • RSocketStrategiesAutoConfiguration:使用CBOR和Jackson配置数据交互的编码和解码;
  • RSocketMessagingAutoConfiguration:在Spring Messaging中配置Spring RSocket的支持;

客户端配置:

  • RSocketRequesterAutoConfiguration:配置一个RSocketRequester.Builder的Bean用来定义RSocketRequester
5.3 示例
5.3.1 Server
  • 配置RSocket Server和连接MongoDB

    spring:
      rsocket:
        server:
          address: localhost
          port: 9898
          transport: tcp #使用tcp协议监听localhost的9898端口
      data:
        mongodb:
          host: localhost
          port: 27017
          username: wisely
          password: zzzzzz
          database: first_db
    
  • 领域模型和Repository

    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    @Document(collection = "people")
    public class Person {
         
         
        @Id
        private String id;
        private String name;
        private Integer age;
        public Person(String name, Integer age) {
         
         
            this.name = name;
            this.age = age;
        }
    
    }
    
    public interface PersonRepository extends ReactiveMongoRepository<Person, String> {
         
         
    }
    
  • RSocket Server

    RSocket是Spring Messaging集成的,同样也使用@MessageMapping定义消息的终点。

    @Controller
    public class PersonController {
         
         
    
        PersonRepository personRepository;
    
        public PersonController(PersonRepository personRepository) {
         
         
            this.personRepository = personRepository;
        }
    
    
        @MessageMapping("people.findById") 
        Mono<Person> getOne(Person person){
         
          //1
            return personRepository.findById
<think>嗯,用户需要推荐Spring相关书籍。根据之前的引用内容,我有四本相关书籍的参考资料,分别涉及Spring Boot开发、Spring源码分析、微服务开发以及Java编程思想中的Spring部分。 我需要整理这些信息,按照不同学习方向分类推荐。用户可能是Java开发者,可能是初学者也可能是有一定基础的用户。 对于初学者,应该推荐入门实践型的书籍如Spring Boot开发书籍。对于想深入理解Spring原理的用户,应该推荐源码解析类书籍。微服务是当前热门方向,所以也要单独推荐相关书籍。最后,Java编程思想是进阶必读书籍,虽然不专门讲Spring但对理解底层很有帮助。 准备将书籍分为四个类别:入门实践、源码解析、微服务开发、思想进阶。每个类别推荐1-2本书籍,并简要说明推荐理由和适合人群。 在最后考虑添加一个总结表格,方便用户快速比较选择。表格包含书名、类别、难度和特色四个维度。 用户可能还关心如何获取这些书籍,可以提示在亚马逊或国内电商平台购买。 相关的问题建议可以从这几个角度延伸:不同阶段的学习路径规划、电子书资源获取、书籍配套资源、最新版本更新情况等。这样能覆盖用户可能感兴趣的其他方面。 </think>以下是基于Spring技术栈不同学习方向的精选书籍推荐,结合核心知识点和适用人群分类整理: --- ### **一、入门实践(Spring Boot开发)** 1. **《Spring Boot实战》** - **亮点**:从零构建企业级应用,覆盖自动配置、REST API、数据访问等核心功能 - **适合人群**:需快速上手实际项目的开发者 - **实践案例**:电商系统开发全流程演示(含安全与部署)[^1] 2. **《Spring Boot编程思想(核心篇)》** - **深度解析**: - 自动装配原理(`@EnableAutoConfiguration`源码追踪) - `SpringApplication`生命周期事件机制 - **特色**:关联JSR规范(如JPA、JCache)与Spring生态演进[^4] --- ### **二、源码深度解析** **《Spring源码深度解析》(郝佳 著)** - **核心解剖**: ```mermaid graph LR A[IOC容器] --> B[BeanFactory设计模式] A --> C[依赖注入实现] D[AOP] --> E[动态代理机制] D --> F[事务管理底层] ``` - **价值点**: - 图解Bean生命周期(实例化→依赖注入→初始化→销毁) - 事务传播行为(`PROPAGATION_REQUIRED`等)的源码级验证[^2] --- ### **三、云原生与微服务** **《Spring Cloud Alibaba微服务开发零基础入门到实操》** - **技术栈覆盖**: | 组件 | 功能 | 书中章节 | |---------------|---------------------|----------| | Nacos | 服务注册与配置中心 | 第4章 | | Sentinel | 流量控制与熔断 | 第7章 | | Seata | 分布式事务 | 第9章 | - **特色实践**: - 基于Spring Cloud Gateway的鉴权设计 - 微服务链路追踪(SkyWalking集成)[^3] --- ### **四、思想进阶(Java与Spring结合)** 1. **《Java编程思想(第4版)》** - **必读章节**:泛型、注解、并发编程(为理解Spring注解驱动开发奠基) 2. **《Spring实战(第6版)》** - **新特性重点**: - Reactive编程(WebFlux响应式模型) - RSocket协议集成实战 --- ### **五、选书建议矩阵** | 目标 | 首选推荐 | 备选方案 | |--------------------------|-----------------------------------|-------------------------| | 快速产出商业项目 | 《Spring Boot实战》 | 《Spring实战》 | | 面试/框架原理深造 | 《Spring源码深度解析》 | 《Spring Boot编程思想》 | | 微服务架构落地 | 《Spring Cloud Alibaba...》 | 《Spring微服务实战》 | | 理解Java生态设计哲学 | 《Java编程思想》+《Spring实战》 | —— | > 注:最新版Spring 6.x已全面支持JDK 17,建议选择2022年后修订版本 --- **相关问题延伸** 1. 对于已有Spring基础的学习者,如何制定源码阅读路线图? 2. Spring Boot 3.0的新特性如GraalVM原生镜像支持,哪些书籍有详细解读? 3. 微服务场景下,Spring Cloud Alibaba与Spring Cloud Netflix的选型对比? 4. 如何通过项目实践巩固《Spring源码深度解析》中的理论? [^1]: Spring Boot企业级开发权威指南 [^2]: Spring框架核心机制源码级剖析 [^3]: 云原生微服务开发全景实战 [^4]: Java生态与Spring设计哲学融合
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值