文章詳情頁
java - 多客戶端如何操作MQ比較合適
瀏覽:107日期:2023-12-18 17:37:19
問題描述
我有500個子應用分別部署在500臺不同的服務器上,還有一個主應用,現在有一個MQ。 我主應用會給子應用發消息。 子應用上有很多功能,都需要用到不同的消息。
我是在子應用開一個consumer好,還是為子應用的每一個功能都開一個consumer好。
我目前打算是這樣,每個子應用,只開一個consumer,然后在發送的消息里面定義,具體要操作的方法。格式如下:
{ 'header': {'action': 'scan_address' }, 'body': { 'id': 1234, 'name': 'xxxxxx' }}
當子應用拿到消息后,根據action來決定調用哪個方法。 然后body就是需要處理的業務數據。
問題解答
回答1:你這種情況屬于用MQ做松耦合的RPC調用。 我不知道你的mq選型是什么。就按照我熟悉的kafka來說吧,可以使用一個topic,然后單臺機器配置單個消費組,然后消息就按照RPC的那種去寫,基本可以做到不重不丟,且服務上下游解耦
標簽:
java
相關文章:
1. mysql - 記得以前在哪里看過一個估算時間的網站2. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””3. docker綁定了nginx端口 外部訪問不到4. dockerfile - 為什么docker容器啟動不了?5. angular.js - angular內容過長展開收起效果6. javascript - 能否讓vue-cli的express修改express重啟服務7. macos - mac下docker如何設置代理8. docker鏡像push報錯9. docker內創建jenkins訪問另一個容器下的服務器問題10. 請教各位大佬,瀏覽器點 提交實例為什么沒有反應
排行榜
