springCloud項目搭建流程步驟分解
實現(xiàn)跨服務的遠程調(diào)用(RestTemplate)
業(yè)務場景:在返回訂單信息數(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è)務代碼
@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;
}
提供者和消費者
服務提供者:一次業(yè)務中,被其他微服務調(diào)用的服務(提供接口給其他微服務) 如上的user微服務
服務消費者:一次業(yè)務中,調(diào)用其他微服務的服務(調(diào)用其他微服務提供的接口) 如上的order微服務
服務A調(diào)用服務B,服務B調(diào)用服務C,那么服務B是什么角色?
答案:要看B相對誰而言,一個服務既可以是提供者又可以是消費者,因為提供者和消費者的角色是相對的.
Eureka注冊中心

內(nèi)部協(xié)調(diào)原理
消費者該如何獲取服務提供者具體信息?
1.服務提供者啟動時向eureka注冊自己的信息
2.eureka保存這些信息
3.消費者根據(jù)服務名稱向eureka拉取提供者信息
如果有多個服務提供者,消費者該如何選擇?
1.服務消費者利用負載均衡算法,從服務列表中挑選一個
消費者如何感知服務提供者健康狀態(tài)?
1.服務提供者會每隔30s向eurekaServer發(fā)送心跳請求,報告健康狀態(tài)
2.eureka會更新記錄服務列表信息,心跳不正常會被剔除
3.消費者就可以拉到最新的信息
Eeruka原理
在Eureka架構中,微服務角色有兩類
1:EurekaServer: 服務端 注冊中心
記錄服務信息
心跳監(jiān)控
2:EurekaClient:客戶端
Privider: 服務提供者,案例中的user-service
注冊自己的信息到EurekaServer
每隔30s向EurekaServer發(fā)送心跳
consumer: 服務消費者 案例中的order-service
根據(jù)服務名稱從EurekaServer拉取服務列表
基于服務列表做負載均衡,選中一個微服務后發(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 #服務端口
spring:
application:
name: eurekaserver #eureka的服務名稱
eureka:
client:
service-url: #eureka的地址信息
defaultZone:http://127.0.0.1:10086/eureka
Eeruka-服務注冊
將user-service服務注冊到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客戶端 的服務名稱
eureka:
client:
service-url: #eureka的地址信息
defaultZone: http://127.0.0.1:10086/eureka
將order-service服務注冊到EurekaServer 重復上述1、2操作 Eeruka-服務發(fā)現(xiàn)
在order-service完成服務拉取
服務拉取基于服務名稱獲取服務列表,然后對服務類表做負載均衡
1.修改OrderService代碼,修改訪問的url路徑,用服務名代替ip,端口
String url="http://userservice/user/"+order.getUerId();
2.在order-service項目的啟動類OrderApplication中的RestTemplate添加負載均衡注解
@Bean
@LoadBalanced /*添加的注解*/
public RestTemplate restTemplate(){
return new RestTemplate();
}
到此這篇關于springCloud項目搭建流程步驟分解的文章就介紹到這了,更多相關springCloud搭建流程內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
自定義注解實現(xiàn)Spring容器注入Bean方式(類似于mybatis的@MapperScans)
本文介紹了如何通過自定義注解@MyService和@MyServiceScans在SpringBoot項目中自動將指定包下的類注入Spring容器,詳細解釋了創(chuàng)建自定義注解、定義包掃描器ClassPathBeanDefinitionScanner的作用與實現(xiàn)2024-09-09
Java+Selenium調(diào)用JavaScript的方法詳解
這篇文章主要為大家講解了java在利用Selenium操作瀏覽器網(wǎng)站時候,有時會需要用的JavaScript的地方,代碼該如何實現(xiàn)呢?快跟隨小編一起學習一下吧2023-01-01
Java使用Spring JdbcTemplate向in語句中傳遞參數(shù)的教程詳解
這篇文章主要給大家介紹Java如何使用Spring JdbcTemplate向in語句中傳遞參數(shù),文中有詳細的流程步驟和代碼示例,需要的朋友可以參考下2023-07-07
如何使用Spring Boot實現(xiàn)自定義Spring Boot插件
在本文中,我們介紹了如何使用 Spring Boot 實現(xiàn)自定義插件,使用自定義插件可以幫助我們快速地添加一些額外的功能,提高系統(tǒng)的可擴展性和可維護性,感興趣的朋友跟隨小編一起看看吧2023-06-06

