springCloud項(xiàng)目搭建流程步驟分解
實(shí)現(xiàn)跨服務(wù)的遠(yuǎn)程調(diào)用(RestTemplate)
業(yè)務(wù)場景:在返回訂單信息數(shù)據(jù)中顯示用戶信息
實(shí)現(xiàn)思路:基于RestTemplate發(fā)起的http請求實(shí)現(xiàn)遠(yuǎ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; }
提供者和消費(fèi)者
服務(wù)提供者:一次業(yè)務(wù)中,被其他微服務(wù)調(diào)用的服務(wù)(提供接口給其他微服務(wù)) 如上的user微服務(wù)
服務(wù)消費(fèi)者:一次業(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相對誰而言,一個(gè)服務(wù)既可以是提供者又可以是消費(fèi)者,因?yàn)樘峁┱吆拖M(fèi)者的角色是相對的.
Eureka注冊中心
內(nèi)部協(xié)調(diào)原理
消費(fèi)者該如何獲取服務(wù)提供者具體信息?
1.服務(wù)提供者啟動時(shí)向eureka注冊自己的信息
2.eureka保存這些信息
3.消費(fèi)者根據(jù)服務(wù)名稱向eureka拉取提供者信息
如果有多個(gè)服務(wù)提供者,消費(fèi)者該如何選擇?
1.服務(wù)消費(fèi)者利用負(fù)載均衡算法,從服務(wù)列表中挑選一個(gè)
消費(fèi)者如何感知服務(wù)提供者健康狀態(tài)?
1.服務(wù)提供者會每隔30s向eurekaServer發(fā)送心跳請求,報(bào)告健康狀態(tài)
2.eureka會更新記錄服務(wù)列表信息,心跳不正常會被剔除
3.消費(fèi)者就可以拉到最新的信息
Eeruka原理
在Eureka架構(gòu)中,微服務(wù)角色有兩類
1:EurekaServer: 服務(wù)端 注冊中心
記錄服務(wù)信息
心跳監(jiān)控
2:EurekaClient:客戶端
Privider: 服務(wù)提供者,案例中的user-service
注冊自己的信息到EurekaServer
每隔30s向EurekaServer發(fā)送心跳
consumer: 服務(wù)消費(fèi)者 案例中的order-service
根據(jù)服務(wù)名稱從EurekaServer拉取服務(wù)列表
基于服務(wù)列表做負(fù)載均衡,選中一個(gè)微服務(wù)后發(fā)起遠(yuǎn)程調(diào)用
搭建Eeruka
1.創(chuàng)建項(xià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項(xiàng)目引入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ù)類表做負(fù)載均衡
1.修改OrderService代碼,修改訪問的url路徑,用服務(wù)名代替ip,端口
String url="http://userservice/user/"+order.getUerId();
2.在order-service項(xiàng)目的啟動類OrderApplication中的RestTemplate添加負(fù)載均衡注解
@Bean
@LoadBalanced /*添加的注解*/
public RestTemplate restTemplate(){
return new RestTemplate();
}
到此這篇關(guān)于springCloud項(xiàng)目搭建流程步驟分解的文章就介紹到這了,更多相關(guān)springCloud搭建流程內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Eclipse+Java+Swing+Mysql實(shí)現(xiàn)電影購票系統(tǒng)(詳細(xì)代碼)
這篇文章主要介紹了Eclipse+Java+Swing+Mysql實(shí)現(xiàn)電影購票系統(tǒng)并附詳細(xì)的代碼詳解,需要的小伙伴可以參考一下2022-01-01Java 定時(shí)器(Timer)及線程池里使用定時(shí)器實(shí)例代碼
這篇文章主要介紹了Java 定時(shí)器(Timer)及線程池里使用定時(shí)器實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2016-12-12使用Java實(shí)現(xiàn)一個(gè)解析CURL腳本小工具
文章介紹了如何使用Java實(shí)現(xiàn)一個(gè)解析CURL腳本的工具,該工具可以將CURL腳本中的Header解析為KV Map結(jié)構(gòu),獲取URL路徑、請求類型,解析URL參數(shù)列表和Body請求體,感興趣的小伙伴跟著小編一起來看看吧2025-02-02Springboot應(yīng)用中Mybatis輸出SQL日志的3種方法代碼示例
在前臺請求數(shù)據(jù)的時(shí)候,sql語句一直都是打印到控制臺的,有一個(gè)想法就是想讓它打印到日志里,該如何做呢?這篇文章主要給大家介紹了關(guān)于Springboot應(yīng)用中Mybatis輸出SQL日志的3種方法,需要的朋友可以參考下2024-01-01關(guān)于maven打包時(shí)的報(bào)錯(cuò): Return code is: 501 , ReasonPhrase:HTTPS Requ
這篇文章主要介紹了關(guān)于maven打包時(shí)的報(bào)錯(cuò): Return code is: 501 , ReasonPhrase:HTTPS Required,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09