文章詳情頁
java - 多客戶端如何操作MQ比較合適
瀏覽:212日期: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. boot2docker無法啟動2. docker-compose中volumes的問題3. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””4. java - SSH框架中寫分頁時service層中不能注入分頁類5. nignx - docker內nginx 80端口被占用6. docker安裝后出現Cannot connect to the Docker daemon.7. javascript - mock.js可以存儲數據嗎8. docker api 開發的端口怎么獲取?9. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?10. golang - 用IDE看docker源碼時的小問題
排行榜

網公網安備