• <s id="pxxfn"></s>
    首頁 >

    使用 Spring Cloud Bus 在微服務之間傳遞消息示例|世界看點


    來源: 騰訊云


    (資料圖片)

    下面是一個完整的示例,演示如何使用 Spring Cloud Bus 在微服務之間傳遞消息。該示例包含兩個微服務,一個是消息發送者,另一個是消息接收者。

    首先,我們需要創建一個 Spring Boot 項目,并添加 Spring Cloud Bus 和 RabbitMQ 的依賴。在 pom.xml 文件中添加以下依賴:

        org.springframework.cloud    spring-cloud-starter-bus-amqp    2.2.1.RELEASE    org.springframework.boot    spring-boot-starter-web    2.2.1.RELEASE    org.springframework.boot    spring-boot-starter-amqp    2.2.1.RELEASE

    在創建的項目中,我們定義了一個消息類型 MyMessage,該類型包含一個字符串類型的 content 屬性。

    javaCopy codepublic class MyMessage implements Serializable {    private static final long serialVersionUID = 1L;    private String content;    public MyMessage(String content) {        this.content = content;    }    public String getContent() {        return content;    }    public void setContent(String content) {        this.content = content;    }}

    然后,我們創建了一個消息發送者,該發送者使用 Spring Cloud Bus 發送消息。

    @RestControllerpublic class MyController {    @Autowired    private MessageSender messageSender;    @PostMapping("/send")    public void sendMessage(@RequestBody MyMessage message) {        messageSender.sendMessage(message);    }}@Servicepublic class MessageSender {    private static final Logger LOGGER = LoggerFactory.getLogger(MessageSender.class);    @Autowired    private MessageChannel output;    public void sendMessage(MyMessage message) {        LOGGER.info("Sending message: {}", message.getContent());        output.send(MessageBuilder.withPayload(message).build());    }}@Servicepublic class MessageListener {    private static final Logger LOGGER = LoggerFactory.getLogger(MessageListener.class);    @StreamListener(target = Sink.INPUT, condition = "headers["type"]=="MyMessage"")    public void handleMessage(MyMessage message) {        LOGGER.info("Received message: {}", message.getContent());    }}

    在這個例子中,我們創建了一個 MyController 類,該類定義了一個發送消息的 API 接口,接收一個 MyMessage 類型的參數,將參數傳遞給 MessageSender 類的 sendMessage() 方法。

    MessageSender 類定義了一個 sendMessage() 方法,該方法使用 Spring Cloud Stream 的 output 消息通道發送消息。

    MessageListener 類定義了一個 handleMessage() 方法,該方法使用 @StreamListener 注解監聽 Spring Cloud Stream 的 input 消息通道,并根據消息類型過濾消息。當有符合條件的消息到達時,handleMessage() 方法會被自動調用,處理接收到的消息。

    在以上代碼中,我們使用了 @Autowired 注解自動注入了 MessageSender 和 MessageListener 類,這是 Spring Boot 自帶的依賴注入功能。

    運行應用程序后,我們可以使用 Postman 工具或其他 HTTP 工具發送 HTTP POST 請求,將消息發送到消息發送者的 API 接口,如下所示:

    POST http://localhost:8080/send HTTP/1.1Content-Type: application/json{    "content": "Hello, World!"}

    當消息到達時,消息接收者會打印消息內容,如下所示:

    2023-04-19 09:24:47.836  INFO 29740 --- [afka-listener-1] com.example.demo.M

    [責任編輯:cqsh]

    網羅天下

    igao国产精品,iGaO激情,igao激情视频在线观看,iGAO为爱高激情,IGAO为爱搞点激情视频,igao为爱稿点在线观看,IGAO为爱寻找激情,IGAO在线播放,91中文字幕永久在线,91专区 约熟女,91自拍视频在线,18岁禁看网站,18岁禁止的黄片,18岁禁止黄片,18岁禁止网站,18岁禁止网站在线观看,好黄好爽好猛好痛视频真人版,好黄好爽好舒服视频,好黄好爽好想喷水的视频,2020国内自拍偷拍,2020国内自拍性爱视频,2020精品视频自拍,2020年色视频在线,2020欧美精品A∨