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