1,eureka 是Netflix開發的服務發現框架,自己是一個 基於REST的服務,主要用於定位運行在AWS域中的中間層服務,以達到 負載均衡 和 中間層服務故障轉移的目的。spring cloud將其 集成在 子項目 spring-cloud-Netflix 中,以實現 spring cloud的服務發現功能。算法
2,spring
Eureka包含兩個組件:Eureka Server 和 Eureka Client。
Eureka Server提供服務註冊服務,各個節點啓動後,會在Eureka Server中進行註冊,這樣Eureka Server中的服務註冊表中將會存儲全部可用服務節點的信息,服務節點的信息能夠在界面中直觀的看到。
Eureka Client是一個Java客戶端,用於簡化與Eureka Server的交互,客戶端同時也具有一個內置的、使用輪詢(round-robin)負載算法的負載均衡器。
在應用啓動後,將會向Eureka Server發送心跳(默認週期爲30秒)。若是Eureka Server在多個心跳週期內沒有接收到某個節點的心跳,Eureka Server將會從服務註冊表中把這個服務節點移除(默認90秒)。
Eureka Server之間將會經過複製的方式完成數據的同步。(詳見Eureka高可用章節)
Eureka還提供了客戶端緩存的機制,即便全部的Eureka Server都掛掉,客戶端依然能夠利用緩存中的信息消費其餘服務的API。
綜上,Eureka經過心跳檢測、健康檢查、客戶端緩存等機制,確保了系統的高可用性、靈活性和可伸縮性。緩存