<ul id="ouw02"></ul>
  • 首頁 > 綜合 > 正文

    全球視訊!配置Spring Cloud Bus并集成消息代理示例

    2023-04-17 14:17:43來源:騰訊云  

    我們將創(chuàng)建兩個微服務(wù):一個是 Order Service,另一個是 Product Service。這兩個服務(wù)將使用 Spring Cloud Bus 和 RabbitMQ 來進(jìn)行消息傳遞。

    Order Service

    首先,讓我們來創(chuàng)建 Order Service。


    (資料圖)

    @SpringBootApplication@RestController@EnableBinding(Sink.class)public class OrderServiceApplication {    private final Logger logger = LoggerFactory.getLogger(getClass());    @StreamListener(Sink.INPUT)    public void handle(String message) {        logger.info("Received message: {}", message);    }    @GetMapping("/order")    public String placeOrder() {        String message = "Order placed";        logger.info("Sending message: {}", message);        return message;    }    public static void main(String[] args) {        SpringApplication.run(OrderServiceApplication.class, args);    }}

    這個應(yīng)用程序使用 @EnableBinding 注解將 Sink綁定到它的消息代理上。它還使用 @StreamListener 注解來指定消息處理方法。

    在 Order Service 中,我們還定義了一個 /order REST 端點。當(dāng)該端點被調(diào)用時,應(yīng)用程序會向消息代理發(fā)送一條消息。該消息將被 Product Service 接收并處理。

    Product Service

    接下來,讓我們來創(chuàng)建 Product Service。

    @SpringBootApplication@RestController@EnableBinding(Source.class)public class ProductServiceApplication {    private final Logger logger = LoggerFactory.getLogger(getClass());    private final MessageChannel output;    public ProductServiceApplication(Source source) {        this.output = source.output();    }    @PostMapping("/product")    public String addProduct(@RequestBody String product) {        String message = "Product added: " + product;        logger.info("Sending message: {}", message);        output.send(MessageBuilder.withPayload(message).build());        return message;    }    public static void main(String[] args) {        SpringApplication.run(ProductServiceApplication.class, args);    }}

    這個應(yīng)用程序使用 @EnableBinding 注解將 Source 綁定到它的消息代理上。它還定義了一個 /product REST 端點,該端點用于添加新產(chǎn)品。

    當(dāng) /product 端點被調(diào)用時,Product Service 會向消息代理發(fā)送一條消息,該消息將被 Order Service 接收并處理。

    4.3 運行示例

    我們已經(jīng)創(chuàng)建了 Order Service 和 Product Service,接下來讓我們運行它們并查看消息傳遞的結(jié)果。

    首先,我們需要啟動 RabbitMQ 服務(wù)器。然后,我們可以使用以下命令分別啟動 Order Service 和 Product Service:

    mvn spring-boot:run -Dspring-boot.run.arguments=--server.port=8081 (Order Service)mvn spring-boot:run -Dspring-boot.run.arguments=--server.port=8082 (Product Service)

    當(dāng)這兩個服務(wù)都已經(jīng)啟動時,我們可以通過訪問 Order Service 的 /order 端點和 Product Service 的 /product 端點來測試它們之間的消息傳遞。

    在 Order Service 的控制臺輸出中,我們應(yīng)該能夠看到類似以下內(nèi)容的消息:

    Received message: Product added: {product name}

    這表明 Product Service 成功地向 Order Service 發(fā)送了一條消息,并且 Order Service 成功地接收并處理了該消息。

    標(biāo)簽:

    相關(guān)閱讀

    精彩推薦

    相關(guān)詞

    推薦閱讀

    亚洲JLZZJLZZ少妇| 4444亚洲国产成人精品| 国产午夜亚洲精品不卡| 亚洲伊人久久大香线蕉影院| 亚洲码国产精品高潮在线| 亚洲gay片在线gv网站| 国产精品亚洲片在线va| 亚洲嫩草影院在线观看| 亚洲国产成人精品无码区在线秒播| 亚洲免费视频一区二区三区| 亚洲成人高清在线| 成人亚洲国产精品久久| 全亚洲最新黄色特级网站| 国产亚洲精品第一综合| 亚洲精品国产日韩无码AV永久免费网| 亚洲AV无码一区二区一二区| 国产成人精品日本亚洲语音 | 亚洲视频在线精品| 亚洲午夜精品久久久久久浪潮| 亚洲一区二区精品视频| 中文字幕无码精品亚洲资源网| 久久精品亚洲福利| 国产AV无码专区亚洲AV手机麻豆| 亚洲精品NV久久久久久久久久| 亚洲精品第一国产综合精品99| mm1313亚洲国产精品美女| 国产亚洲一卡2卡3卡4卡新区| 国产91成人精品亚洲精品| 亚洲一区日韩高清中文字幕亚洲 | 亚洲乱亚洲乱妇无码| 亚洲中文字幕无码久久| 亚洲欧美成aⅴ人在线观看| 亚洲AV无码一区二区乱子仑 | 亚洲av中文无码乱人伦在线观看| 国产精品亚洲综合| 2022中文字字幕久亚洲| 亚洲va久久久噜噜噜久久男同 | 亚洲AV无码不卡在线播放| 亚洲色大成网站www永久| 亚洲人成网站色在线观看| 亚洲国产精品无码久久|