SpringCloud學習筆記 服務消費

2021-10-01 13:47:32 字數 2284 閱讀 9644

在前文中我們已經搭建了高可用的註冊中心,並向註冊中心註冊了兩個服務,hello-service,現在已經有了服務的提供方,那麼自然也要有服務的消費方,這篇文章就來搭建乙個服務消費者,可以發現並且消費服務。服務的發現是由eureka的客戶端完成的,而服務的消費是由ribbon完成的。ribbon是乙個負載均衡器,在客戶端配置了ribbonserverlist後即可達到負載均衡的效果,先不深究ribbon的具體實現原理,我們只需要理解它可以做到負載均衡,配合eureka的服務發現機制可以達到選擇服務例項的目的從而實現服務消費

首先我們啟動前文中搭建的兩個註冊中心和兩個hello-service例項,啟動後在註冊中心的管理介面應該可以看到如下的服務:

接下來仿照前面的專案,再建立乙個新專案叫做ribbon-consumer,配置同樣非常簡單,在啟動類上加入註解@enablediscoveryclient即可讓應用註冊為eureka的客戶端並具有發現服務的能力,同時在啟動類中注入resttemplate,並通過註解@loadbalance註解開啟該客戶端的負載均衡功能,啟動類**如下:

@enablediscoveryclient

@bean

@loadbalanced

resttemplate resttemplate()

public static void main(string args)

}

配置了啟動類之後我們再新建乙個consumercontroller類,在該類中實現乙個/ribbon-consumer介面,該介面通過resttemplate呼叫hello-service的/hello介面,注意在**中我們只需要指定service name,即hello-service,而並不需要輸入具體的host和port,這也是服務治理框架中乙個非常重要的特性,你需要知道的是服務,而不是背後具體的伺服器,否則的話就和乙個http呼叫的rpc介面請求沒什麼區別了,controller參考**如下:

全部配置完成後啟動ribbon-consumer專案,在eureka的資訊面板頁面應該會發現多了乙個ribbon-consumer應用,至此說明我們的服務發現和消費服務已經成功註冊到了註冊中心,接下來我們需要測試一下,不過在測試前我們可以優化一下之前hello-service的返回值,由於ribbon-consumer採用了負載均衡,而且我們有兩個hello-service提供服務,所以我們可以通過在介面返回中列印具體的server埠號來區分呼叫被傳送到了哪個server上,所以這裡我們稍微改一下之前的/hello介面,在專案log和返回值中都加入一些資訊:

@restcontroller

public class hellocontroller

int port = serverconfig.getserverport();

for (serviceinstance si : instances)

}return null;}}

現在我們重啟一下hello-service,然後可以直接在瀏覽器中訪問http://localhost:3333/ribbon-consumer ,我們可以看到返回了hello world @2221, 我們重新重新整理一下頁面,會發現變成了hello world @2222,說明我們不僅成功的發現服務並且進行了

另外有興趣的朋友可以觀察一下各個專案控制台中的日誌,為我們列印了關於請求數,連線數,連線資訊,失敗資訊等有用的資訊供大家在實際工作學習排查問題。那麼至此,微服務框架就已經具有了乙個高可用註冊中心,兩個服務提供者hello-service,和乙個服務發現者ribbon-consumer。

SpringCloud學習筆記

筆記學習位址 筆記內容皆摘抄自以上部落格並親自驗證。在此感謝原博主分享 本文出自方志朋的部落格 環境 ide idea jdk8 a 服務的註冊與發現 1 spring eureka 服務端 實現springcloud的服務註冊與發現功能。1 springboot專案搭建 使用start.sprin...

Spring Cloud 學習筆記

spring cloud學習筆記 系統架構 集中式架構,垂直拆分,分布式服務,服務治理,微服務 集中式架構 把所有功能集中部署,低成本,但無法適用於稍複雜的系統 垂直拆分 通過將每個業務功能拆分來實現流量分擔,每個模組也可單獨優化且方便水平擴充套件,但會有很多重複工作,影響開發效率。分布式服務 抽取...

筆記 spring cloud 學習筆記

1 spring cloud 是什麼 spring cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具 例如配置管理,服務發現,斷路器,智慧型路由,微 控制匯流排 分布式系統的協調導致了樣板模式,使用spring cloud開發人員可以快速地支援實現這些模式的服務和應用程式。他們將在任...