您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“springCloud項目搭建流程是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“springCloud項目搭建流程是什么”吧!
實現(xiàn)跨服務(wù)的遠程調(diào)用(RestTemplate)
業(yè)務(wù)場景:在返回訂單信息數(shù)據(jù)中顯示用戶信息
實現(xiàn)思路:基于RestTemplate發(fā)起的http請求實現(xiàn)遠程調(diào)用
1.注冊RestTemplate
//在order-service的啟動類中注冊RestTemplate的Bean @Bean public RestTemplate restTemplate(){ return new RestTemplate(); }
2.改造OrderController
2.1:注入RestTemplate
@Autowired private RestTemplate restTemplate;
2.2:修改業(yè)務(wù)代碼
@GetMapping("{orderId}") public Order queryOrderByUserId(@PathVariable("orderId") Long orderId) { // 根據(jù)id查詢訂單并返回 Order order = orderService.queryOrderById(orderId); //利用RestTemplate發(fā)起http請求查詢用戶信息 User user = restTemplate.getForObject("http://localhost:8091/user/" + order.getUserId(), User.class); //封裝user信息到返回值中 order.setUser(user); return order; }
提供者和消費者
服務(wù)提供者:一次業(yè)務(wù)中,被其他微服務(wù)調(diào)用的服務(wù)(提供接口給其他微服務(wù)) 如上的user微服務(wù)
服務(wù)消費者:一次業(yè)務(wù)中,調(diào)用其他微服務(wù)的服務(wù)(調(diào)用其他微服務(wù)提供的接口) 如上的order微服務(wù)
服務(wù)A調(diào)用服務(wù)B,服務(wù)B調(diào)用服務(wù)C,那么服務(wù)B是什么角色?
答案:要看B相對誰而言,一個服務(wù)既可以是提供者又可以是消費者,因為提供者和消費者的角色是相對的.
Eureka注冊中心
內(nèi)部協(xié)調(diào)原理
消費者該如何獲取服務(wù)提供者具體信息?
1.服務(wù)提供者啟動時向eureka注冊自己的信息
2.eureka保存這些信息
3.消費者根據(jù)服務(wù)名稱向eureka拉取提供者信息
如果有多個服務(wù)提供者,消費者該如何選擇?
1.服務(wù)消費者利用負載均衡算法,從服務(wù)列表中挑選一個
消費者如何感知服務(wù)提供者健康狀態(tài)?
1.服務(wù)提供者會每隔30s向eurekaServer發(fā)送心跳請求,報告健康狀態(tài)
2.eureka會更新記錄服務(wù)列表信息,心跳不正常會被剔除
3.消費者就可以拉到最新的信息
Eeruka原理
在Eureka架構(gòu)中,微服務(wù)角色有兩類
1:EurekaServer: 服務(wù)端 注冊中心
記錄服務(wù)信息
心跳監(jiān)控
2:EurekaClient:客戶端
Privider: 服務(wù)提供者,案例中的user-service
注冊自己的信息到EurekaServer
每隔30s向EurekaServer發(fā)送心跳
consumer: 服務(wù)消費者 案例中的order-service
根據(jù)服務(wù)名稱從EurekaServer拉取服務(wù)列表
基于服務(wù)列表做負載均衡,選中一個微服務(wù)后發(fā)起遠程調(diào)用
搭建Eeruka
1.創(chuàng)建項目,引入spring-cloud-starter-netflix-eureka-server的依賴
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId> </dependency>
2.編寫啟動類,添加@EnableEurekaServer注解
3.添加application.yml文件,編寫下面的配置
server:
port: 10086 #服務(wù)端口
spring:
application:
name: eurekaserver #eureka的服務(wù)名稱
eureka:
client:
service-url: #eureka的地址信息
defaultZone:http://127.0.0.1:10086/eureka
Eeruka-服務(wù)注冊
將user-service服務(wù)注冊到EurekaServer
1.在user-service項目引入spring-cloud-starter-netflix-eureka-client的依賴
<!--eureka客戶端依賴--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency>
2.在application.yml文件,編寫下面的配置
spring:
application:
name: userservice #eureka客戶端 的服務(wù)名稱
eureka:
client:
service-url: #eureka的地址信息
defaultZone: http://127.0.0.1:10086/eureka
將order-service服務(wù)注冊到EurekaServer 重復(fù)上述1、2操作 Eeruka-服務(wù)發(fā)現(xiàn)
在order-service完成服務(wù)拉取
服務(wù)拉取基于服務(wù)名稱獲取服務(wù)列表,然后對服務(wù)類表做負載均衡
1.修改OrderService代碼,修改訪問的url路徑,用服務(wù)名代替ip,端口
String url="http://userservice/user/"+order.getUerId();
2.在order-service項目的啟動類OrderApplication中的RestTemplate添加負載均衡注解
@Bean
@LoadBalanced /*添加的注解*/
public RestTemplate restTemplate(){
return new RestTemplate();
}
到此,相信大家對“springCloud項目搭建流程是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。