Spring Boot与NATS的集成

简介: Spring Boot与NATS的集成

Spring Boot与NATS的集成

今天,我们来聊聊如何将Spring Boot与NATS进行集成。

NATS是一种高性能的消息系统,它提供了简单、轻量级的消息发布-订阅、队列、和请求-响应等功能。通过NATS,您可以轻松实现微服务之间的通信。在这篇文章中,我们将详细介绍如何在Spring Boot应用中集成NATS,并通过示例代码来展示其使用方法。

一、引入依赖

首先,我们需要在Spring Boot项目中引入NATS的依赖。在pom.xml中添加如下依赖:

<dependency>
    <groupId>io.nats</groupId>
    <artifactId>jnats</artifactId>
    <version>2.11.2</version>
</dependency>

二、配置NATS连接

接下来,我们需要配置NATS的连接。在Spring Boot项目的application.properties文件中添加如下配置:

nats.url=nats://localhost:4222
nats.connection.name=SpringBootNatsConnection

然后,我们创建一个配置类来初始化NATS连接:

package cn.juwatech.config;

import io.nats.client.Connection;
import io.nats.client.Nats;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

@Configuration
public class NatsConfig {
   

    @Bean
    public Connection natsConnection() throws IOException, InterruptedException, TimeoutException {
   
        return Nats.connect(System.getProperty("nats.url", "nats://localhost:4222"));
    }
}

三、发布消息

我们可以通过NATS连接来发布消息。在一个Spring Boot服务中创建一个消息发布者:

package cn.juwatech.service;

import io.nats.client.Connection;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class NatsPublisher {
   

    @Autowired
    private Connection natsConnection;

    public void publishMessage(String subject, String message) {
   
        try {
   
            natsConnection.publish(subject, message.getBytes());
        } catch (Exception e) {
   
            e.printStackTrace();
        }
    }
}

我们可以在控制器中调用这个服务来发布消息:

package cn.juwatech.controller;

import cn.juwatech.service.NatsPublisher;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class MessageController {
   

    @Autowired
    private NatsPublisher natsPublisher;

    @GetMapping("/publish")
    public String publishMessage(@RequestParam String subject, @RequestParam String message) {
   
        natsPublisher.publishMessage(subject, message);
        return "Message published successfully!";
    }
}

四、订阅消息

为了订阅NATS消息,我们需要创建一个消息订阅者。在Spring Boot项目中实现如下服务:

package cn.juwatech.service;

import io.nats.client.Connection;
import io.nats.client.Dispatcher;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import javax.annotation.PostConstruct;

@Service
public class NatsSubscriber {
   

    @Autowired
    private Connection natsConnection;

    @PostConstruct
    public void subscribe() {
   
        Dispatcher dispatcher = natsConnection.createDispatcher((msg) -> {
   
            String message = new String(msg.getData());
            System.out.println("Received message: " + message);
        });
        dispatcher.subscribe("example-subject");
    }
}

通过这个服务,我们在应用启动时就会自动订阅example-subject主题的消息,并打印收到的消息内容。

五、请求-响应

NATS还支持请求-响应模式,我们可以通过以下示例来实现:

请求者:

package cn.juwatech.service;

import io.nats.client.Connection;
import io.nats.client.Message;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.nio.charset.StandardCharsets;
import java.time.Duration;

@Service
public class NatsRequester {
   

    @Autowired
    private Connection natsConnection;

    public String requestMessage(String subject, String request) {
   
        try {
   
            Message msg = natsConnection.request(subject, request.getBytes(), Duration.ofSeconds(2));
            return new String(msg.getData(), StandardCharsets.UTF_8);
        } catch (Exception e) {
   
            e.printStackTrace();
            return null;
        }
    }
}

响应者:

package cn.juwatech.service;

import io.nats.client.Connection;
import io.nats.client.Dispatcher;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import javax.annotation.PostConstruct;

@Service
public class NatsResponder {
   

    @Autowired
    private Connection natsConnection;

    @PostConstruct
    public void respond() {
   
        Dispatcher dispatcher = natsConnection.createDispatcher((msg) -> {
   
            String request = new String(msg.getData());
            String response = "Received: " + request;
            natsConnection.publish(msg.getReplyTo(), response.getBytes());
        });
        dispatcher.subscribe("example-request");
    }
}

我们可以在控制器中调用请求者服务来发送请求并接收响应:

package cn.juwatech.controller;

import cn.juwatech.service.NatsRequester;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class RequestController {
   

    @Autowired
    private NatsRequester natsRequester;

    @GetMapping("/request")
    public String requestMessage(@RequestParam String subject, @RequestParam String request) {
   
        return natsRequester.requestMessage(subject, request);
    }
}

六、结束语

以上就是Spring Boot与NATS集成的详细步骤和示例代码。通过这种方式,我们可以在Spring Boot应用中高效地使用NATS进行消息通信,实现发布-订阅、请求-响应等功能。希望这篇文章对你有所帮助。

相关文章
|
1月前
|
Java Maven Docker
gitlab-ci 集成 k3s 部署spring boot 应用
gitlab-ci 集成 k3s 部署spring boot 应用
|
3月前
|
资源调度 Java 调度
Spring Cloud Alibaba 集成分布式定时任务调度功能
定时任务在企业应用中至关重要,常用于异步数据处理、自动化运维等场景。在单体应用中,利用Java的`java.util.Timer`或Spring的`@Scheduled`即可轻松实现。然而,进入微服务架构后,任务可能因多节点并发执行而重复。Spring Cloud Alibaba为此发布了Scheduling模块,提供轻量级、高可用的分布式定时任务解决方案,支持防重复执行、分片运行等功能,并可通过`spring-cloud-starter-alibaba-schedulerx`快速集成。用户可选择基于阿里云SchedulerX托管服务或采用本地开源方案(如ShedLock)
121 1
|
1月前
|
前端开发 Java 程序员
springboot 学习十五:Spring Boot 优雅的集成Swagger2、Knife4j
这篇文章是关于如何在Spring Boot项目中集成Swagger2和Knife4j来生成和美化API接口文档的详细教程。
68 1
|
1月前
|
存储 前端开发 Java
Spring Boot 集成 MinIO 与 KKFile 实现文件预览功能
本文详细介绍如何在Spring Boot项目中集成MinIO对象存储系统与KKFileView文件预览工具,实现文件上传及在线预览功能。首先搭建MinIO服务器,并在Spring Boot中配置MinIO SDK进行文件管理;接着通过KKFileView提供文件预览服务,最终实现文档管理系统的高效文件处理能力。
254 11
|
1月前
|
Java Spring
springboot 学习十一:Spring Boot 优雅的集成 Lombok
这篇文章是关于如何在Spring Boot项目中集成Lombok,以简化JavaBean的编写,避免冗余代码,并提供了相关的配置步骤和常用注解的介绍。
81 0
|
4月前
|
资源调度 Java 调度
Spring Cloud Alibaba 集成分布式定时任务调度功能
Spring Cloud Alibaba 发布了 Scheduling 任务调度模块 [#3732]提供了一套开源、轻量级、高可用的定时任务解决方案,帮助您快速开发微服务体系下的分布式定时任务。
14926 30
|
3月前
|
消息中间件 安全 Java
Spring Boot 基于 SCRAM 认证集成 Kafka 的详解
【8月更文挑战第4天】本文详解Spring Boot结合SCRAM认证集成Kafka的过程。SCRAM为Kafka提供安全身份验证。首先确认Kafka服务已启用SCRAM,并准备认证凭据。接着,在`pom.xml`添加`spring-kafka`依赖,并在`application.properties`中配置Kafka属性,包括SASL_SSL协议与SCRAM-SHA-256机制。创建生产者与消费者类以实现消息的发送与接收功能。最后,通过实际消息传递测试集成效果与认证机制的有效性。
135 4
|
3月前
|
人工智能 Java API
JeecgBoot 低代码平台快速集成 Spring AI
Spring 通过 Spring AI 项目正式启用了 AI(人工智能)生成提示功能。本文将带你了解如何在 Jeecg Boot 应用中集成生成式 AI,以及 Spring AI 如何与模型互动,包含 RAG 功能。
123 3
|
3月前
|
XML Java 数据库连接
Spring Boot集成MyBatis
主要系统的讲解了 Spring Boot 集成 MyBatis 的过程,分为基于 xml 形式和基于注解的形式来讲解,通过实际配置手把手讲解了 Spring Boot 中 MyBatis 的使用方式,并针对注解方式,讲解了常见的问题已经解决方式,有很强的实战意义。在实际项目中,建议根据实际情况来确定使用哪种方式,一般 xml 和注解都在用。
|
3月前
|
测试技术 Java Spring
Spring 框架中的测试之道:揭秘单元测试与集成测试的双重保障,你的应用真的安全了吗?
【8月更文挑战第31天】本文以问答形式深入探讨了Spring框架中的测试策略,包括单元测试与集成测试的有效编写方法,及其对提升代码质量和可靠性的重要性。通过具体示例,展示了如何使用`@MockBean`、`@SpringBootTest`等注解来进行服务和控制器的测试,同时介绍了Spring Boot提供的测试工具,如`@DataJpaTest`,以简化数据库测试流程。合理运用这些测试策略和工具,将助力开发者构建更为稳健的软件系统。
54 0