新聞中心
分布式
在大型開發(fā)項(xiàng)目中通常使用分布式服務(wù)來(lái)根據(jù)項(xiàng)目中不同的功能劃分為幾個(gè)不通的模塊。

泰和網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)公司,泰和網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為泰和上千多家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的泰和做網(wǎng)站的公司定做!
比如在一個(gè)商城系統(tǒng)中,通常會(huì)把用戶服務(wù)、下單服務(wù)、商品推薦服務(wù)分散到幾個(gè)模塊中,如果在下單服務(wù)中需要獲取用戶的信息,這時(shí)候就在代碼內(nèi)部調(diào)用用戶服務(wù)的接口即可。這樣一個(gè)過(guò)程就是分布式的基本概念。
Spring Cloud
Spring Cloud是一系列框架的有序集合。它利用Spring Boot的開發(fā)便利性巧妙地簡(jiǎn)化了分布式系統(tǒng)基礎(chǔ)設(shè)施的開發(fā),如服務(wù)發(fā)現(xiàn)注冊(cè)、配置中心、消息總線、負(fù)載均衡、斷路器、數(shù)據(jù)監(jiān)控等,都可以用Spring Boot的開發(fā)風(fēng)格做到一鍵啟動(dòng)和部署。Spring Cloud并沒(méi)有重復(fù)制造輪子,它只是將各家公司開發(fā)的比較成熟、經(jīng)得起實(shí)際考驗(yàn)的服務(wù)框架組合起來(lái),通過(guò)Spring Boot風(fēng)格進(jìn)行再封裝屏蔽掉了復(fù)雜的配置和實(shí)現(xiàn)原理,最終給開發(fā)者留出了一套簡(jiǎn)單易懂、易部署和易維護(hù)的分布式系統(tǒng)開發(fā)工具包。
--以上內(nèi)容來(lái)自百度百科。
圖片
來(lái)自官網(wǎng)列舉的主要項(xiàng)目
所以,Spring Cloud是一款主流的分布式服務(wù)框架,提供了服務(wù)注冊(cè)與調(diào)用,統(tǒng)一配置管理,統(tǒng)一網(wǎng)關(guān)路由,服務(wù)鏈路監(jiān)控等功能。并且在遠(yuǎn)程調(diào)用是支持Feign(HTTP)協(xié)議。
服務(wù)遠(yuǎn)程調(diào)用
3.1 創(chuàng)建兩個(gè)項(xiàng)目
創(chuàng)建兩個(gè)項(xiàng)目模擬分布式的場(chǎng)景,分別是userService和orderService,這兩個(gè)服務(wù)對(duì)應(yīng)的數(shù)據(jù)庫(kù)不在同一個(gè)庫(kù)中,在userService項(xiàng)目中有一個(gè)接口是根據(jù)user表的ID查詢user對(duì)象;
同樣的,orderService項(xiàng)目中有一個(gè)接口是根據(jù)order表的ID查詢order信息,在一條信息中包含了單價(jià),數(shù)量,總價(jià)和用戶的ID。
這兩個(gè)個(gè)項(xiàng)目布在了同一個(gè)大的項(xiàng)目中。現(xiàn)在有一個(gè)功能需求是通過(guò)使用orderService的接口查詢order信息并同時(shí)獲得這個(gè)訂單對(duì)應(yīng)的用戶信息。
圖片
3.2 遠(yuǎn)程調(diào)用
首先需要?jiǎng)?chuàng)建一個(gè)RestTemplate對(duì)象,這個(gè)對(duì)象功能能簡(jiǎn)單,就是用來(lái)發(fā)送HTTP請(qǐng)求,所以可以在項(xiàng)目的配置類中創(chuàng)建這么一個(gè)對(duì)象,然后在Controller層中注入。
圖片
圖片
這樣就完成了一次遠(yuǎn)程調(diào)用了。
使用Postman測(cè)試一下,理論上是要返回一個(gè)response對(duì)象,response對(duì)象包含了user對(duì)象和order對(duì)象。
圖片
Eureka服務(wù)搭建
在上面的遠(yuǎn)程調(diào)用的例子中,有許多的不足,比如訪問(wèn)的url信息是寫死在代碼中的,后期部署的時(shí)候要再專門修改這樣是不現(xiàn)實(shí)的。
Eureka服務(wù)發(fā)現(xiàn)就相當(dāng)于是一個(gè)專門獲取項(xiàng)目中所有接口的程序。所以需要先創(chuàng)建一個(gè)Spring boot項(xiàng)目,然后把這個(gè)項(xiàng)目當(dāng)作Eureka的server。
4.1 首先在Eureka_Server的Maven中導(dǎo)入依賴
org.springframework.cloud
spring-cloud-starter-netflix-eureka-server
4.2 接著在啟動(dòng)類添加@EnableEurekaServer注解
圖片
4.3 在配置文件中配置Eureka服務(wù)的端口和應(yīng)用名稱
圖片
驗(yàn)證是否成功只需要在瀏覽器上輸入設(shè)置的網(wǎng)址,看能否進(jìn)入頁(yè)面即可。
圖片
Eureka服務(wù)注冊(cè)
5.1 在orderservice和userservice項(xiàng)目中分別引入Eureka依賴信息
注:這里導(dǎo)入的是client依賴。
圖片
5.2 在userservice和orderservice配置Eureka的配置信息
注:與4.3的樣式一致。
圖片
5.3 訪問(wèn)eureka地址查看這倆個(gè)新注冊(cè)的服務(wù)
圖片
可以發(fā)現(xiàn)服務(wù)都注冊(cè)在eureka上了。
Eureka服務(wù)發(fā)現(xiàn)
6.1 把消費(fèi)者的調(diào)用鏈接中的ip和端口信息換成注冊(cè)在Eureka的服務(wù)名
圖片
6.2 在消費(fèi)者的配置類的RestTemplate上添加@LoadBalanced注解
注:這里的消費(fèi)者當(dāng)然是orderservice。
圖片
6.3 再測(cè)試一次程序
圖片
可見是成功調(diào)用了userservice的接口。
網(wǎng)頁(yè)題目:實(shí)現(xiàn)Eureka服務(wù)注冊(cè)和服務(wù)發(fā)現(xiàn),你學(xué)會(huì)了嗎?
網(wǎng)站地址:http://www.5511xx.com/article/dpchjhi.html


咨詢
建站咨詢
