<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)詞

    推薦閱讀

    久久精品国产亚洲av影院| 国产亚洲精品精品精品| 中文字幕亚洲一区二区va在线| 久久亚洲精品无码av| 最新亚洲卡一卡二卡三新区| 亚洲一区二区三区久久| 91午夜精品亚洲一区二区三区| 亚洲美女视频一区| 久久久久亚洲AV无码观看| 337p日本欧洲亚洲大胆艺术| 亚洲视频精品在线| 亚洲视频免费播放| 亚洲日本国产乱码va在线观看| 亚洲第一区视频在线观看| 亚洲精品国产福利在线观看| 亚洲精品国产成人| 亚洲国产av美女网站| 在线观看亚洲AV日韩A∨| 亚洲一区二区三区写真| 亚洲国产精品美女久久久久| 无码天堂va亚洲va在线va| 亚洲&#228;v永久无码精品天堂久久 | 国产午夜亚洲精品国产成人小说| 亚洲视频在线免费| 国产亚洲情侣一区二区无| 国产av无码专区亚洲av果冻传媒| 久久国产亚洲精品麻豆| 久久精品国产亚洲av成人| 久久亚洲精品国产精品黑人| 亚洲一二成人精品区| 亚洲综合小说久久另类区| 亚洲视频在线观看网站| 亚洲人成伊人成综合网久久| 亚洲色精品三区二区一区| 妇女自拍偷自拍亚洲精品| 亚洲精品国产自在久久| 亚洲午夜国产精品无码| 亚洲AV天天做在线观看| 久久久久亚洲av无码专区喷水| 亚洲综合免费视频| 亚洲另类小说图片|