面試中提到的微服務(wù)之間通訊方式
我們都知道現(xiàn)在的項(xiàng)目開發(fā)中都是一個(gè)微服務(wù)一個(gè)微服務(wù)的部署,然后每個(gè)微服務(wù)之間都是相對(duì)獨(dú)立的,不會(huì)再像之前的老項(xiàng)目所有的不同的功能模塊都集成在一個(gè)項(xiàng)目中了,但是每個(gè)微服務(wù)之間的通信問題,就成了一個(gè)非常重要的內(nèi)容了。今天了不起就陪著大家來了解一下這個(gè)微服務(wù)之間的通信方式,如果面試官問到了,就看你怎么發(fā)揮了。
圖片
微服務(wù)之間的通信方式
其實(shí)微服務(wù)之間的通信方式,如果讓了不起來回答的話,無非就是三種內(nèi)容,同步通信,異步通信,事件驅(qū)動(dòng)架構(gòu)(EDA),但是也有很多人會(huì)說,實(shí)際上這個(gè)微服務(wù)之間的通信方式也可以歸結(jié)為兩種,一種就是同步通信,一種就是異步通信,而這個(gè)事件驅(qū)動(dòng)架構(gòu)并不能算是一種通信方式,了不起覺得不對(duì),他其實(shí)也算是一種,只不過沒有那么的標(biāo)準(zhǔn)罷了,個(gè)人理解問題,反正只要能回答上兩種,其實(shí)就已經(jīng)算是合乎標(biāo)準(zhǔn)的回答了。
同步通信
微服務(wù)之間通過請(qǐng)求-響應(yīng)的方式進(jìn)行通信,例如 RESTful API 和 RPC。通信過程中,請(qǐng)求方需要等待響應(yīng)方的返回結(jié)果,因此可靠性較高,但可能會(huì)出現(xiàn)請(qǐng)求排隊(duì)、線程阻塞等問題,從而影響系統(tǒng)的響應(yīng)速度和并發(fā)性能。
異步通信
微服務(wù)之間通過消息隊(duì)列進(jìn)行異步通信,例如Kafka和RabbitMQ。通信過程中,發(fā)送方向消息隊(duì)列發(fā)送消息,接收方從消息隊(duì)列中消費(fèi)消息,消息傳輸以異步的方式進(jìn)行,不需要等待接收方的響應(yīng)。由于解耦性高,消息隊(duì)列還可以支持發(fā)布-訂閱模式,消息得以廣播到多個(gè)服務(wù)中,助于構(gòu)建高可伸縮的系統(tǒng)。不過異步通信也可能導(dǎo)致延遲較高,以及可靠性和容錯(cuò)性較差等問題。
事件驅(qū)動(dòng)架構(gòu)(EDA)
微服務(wù)之間通過發(fā)布-訂閱模式進(jìn)行通信,例如Apache Kafka和AWS SNS/SQS。通信過程中,發(fā)布者發(fā)布事件,訂閱者訂閱事件,事件傳遞以異步的方式進(jìn)行。通過EDA,不同服務(wù)之間可以實(shí)現(xiàn)松耦合通信,提高系統(tǒng)的可伸縮性和彈性,但需要謹(jǐn)慎處理網(wǎng)絡(luò)分區(qū)等極端情況,以避免出現(xiàn)一致性等問題。
既然我們都已經(jīng)知道了這個(gè)微服務(wù)之間的通信方式了,那么是不是得看看微服務(wù)通信實(shí)現(xiàn)呢?
微服務(wù)通信實(shí)現(xiàn)
服務(wù)注冊(cè)與發(fā)現(xiàn)
服務(wù)注冊(cè)與發(fā)現(xiàn)是微服務(wù)架構(gòu)的關(guān)鍵組件之一。它允許服務(wù)在啟動(dòng)時(shí)注冊(cè)其自身,并通過服務(wù)發(fā)現(xiàn)機(jī)制向其他服務(wù)公開其位置。為了實(shí)現(xiàn)服務(wù)注冊(cè)與發(fā)現(xiàn),我們通常使用以下組件:
ZooKeeper:
ZooKeeper 是一個(gè)具有高可用性和可擴(kuò)展性的分布式協(xié)調(diào)服務(wù)。它可以用于服務(wù)注冊(cè)和發(fā)現(xiàn),以及配置管理。
- etcd:
etcd 是一個(gè)分布式鍵值存儲(chǔ)系統(tǒng),用于服務(wù)注冊(cè)和發(fā)現(xiàn),并提供強(qiáng)一致性保證。
- Consul:
Consul 是一個(gè)分布式服務(wù)發(fā)現(xiàn)和配置管理系統(tǒng)。它支持多數(shù)據(jù)中心、健康檢查和負(fù)載均衡等功能。
服務(wù)調(diào)用
服務(wù)調(diào)用是微服務(wù)之間通信的另一個(gè)重要組件。它包括客戶端負(fù)載均衡、服務(wù)降級(jí)、熔斷和容錯(cuò)等功能。為了實(shí)現(xiàn)服務(wù)調(diào)用,我們通常使用以下組件:
- Ribbon:
Ribbon 是一個(gè)負(fù)載均衡器,它可以幫助我們?cè)诩褐衅胶庳?fù)載。它支持多種負(fù)載算法和服務(wù)發(fā)現(xiàn),可以與Eureka等注冊(cè)中心集成。
- Feign:
Feign 是一個(gè)聲明式的 REST 客戶端,它使編寫 REST 客戶端變得更加簡(jiǎn)單。我們可以使用注解來定義需要訪問的服務(wù)接口,并且在運(yùn)行時(shí)自動(dòng)生成實(shí)現(xiàn)代碼。
- Hystrix:
Hystrix 是一種容錯(cuò)和熔斷框架,它可以幫助我們處理分布式系統(tǒng)中的故障,并防止故障擴(kuò)散。Hystrix 通過控制線程池和請(qǐng)求隊(duì)列來實(shí)現(xiàn)熔斷機(jī)制,從而避免系統(tǒng)崩潰。
- Resilience4j:
Resilience4j 是一個(gè)輕量級(jí)的容錯(cuò)庫,它提供了諸如熔斷、超時(shí)、重試和限流等功能。與Hystrix相比,Resilience4j提供了更為靈活和集成化的解決方案。
其實(shí)如果你掌握到這些內(nèi)容的時(shí)候,那么面試中問到關(guān)于微服務(wù)之間的通信方式的話,你回答起來應(yīng)該問題就不大了。