springCloud項目搭建流程步驟分解
實現跨服務的遠程調用(RestTemplate)
業務場景:在返回訂單信息數據中顯示用戶信息
實現思路:基於RestTemplate發起的http請求實現遠程調用
1.註冊RestTemplate
//在order-service的啟動類中註冊RestTemplate的Bean @Bean public RestTemplate restTemplate(){ return new RestTemplate(); }
2.改造OrderController
2.1:註入RestTemplate
@Autowired private RestTemplate restTemplate;
2.2:修改業務代碼
@GetMapping("{orderId}") public Order queryOrderByUserId(@PathVariable("orderId") Long orderId) { // 根據id查詢訂單並返回 Order order = orderService.queryOrderById(orderId); //利用RestTemplate發起http請求查詢用戶信息 User user = restTemplate.getForObject("http://localhost:8091/user/" + order.getUserId(), User.class); //封裝user信息到返回值中 order.setUser(user); return order; }
提供者和消費者
服務提供者:一次業務中,被其他微服務調用的服務(提供接口給其他微服務) 如上的user微服務
服務消費者:一次業務中,調用其他微服務的服務(調用其他微服務提供的接口) 如上的order微服務
服務A調用服務B,服務B調用服務C,那麼服務B是什麼角色?
答案:要看B相對誰而言,一個服務既可以是提供者又可以是消費者,因為提供者和消費者的角色是相對的.
Eureka註冊中心
內部協調原理
消費者該如何獲取服務提供者具體信息?
1.服務提供者啟動時向eureka註冊自己的信息
2.eureka保存這些信息
3.消費者根據服務名稱向eureka拉取提供者信息
如果有多個服務提供者,消費者該如何選擇?
1.服務消費者利用負載均衡算法,從服務列表中挑選一個
消費者如何感知服務提供者健康狀態?
1.服務提供者會每隔30s向eurekaServer發送心跳請求,報告健康狀態
2.eureka會更新記錄服務列表信息,心跳不正常會被剔除
3.消費者就可以拉到最新的信息
Eeruka原理
在Eureka架構中,微服務角色有兩類
1:EurekaServer: 服務端 註冊中心
記錄服務信息
心跳監控
2:EurekaClient:客戶端
Privider: 服務提供者,案例中的user-service
註冊自己的信息到EurekaServer
每隔30s向EurekaServer發送心跳
consumer: 服務消費者 案例中的order-service
根據服務名稱從EurekaServer拉取服務列表
基於服務列表做負載均衡,選中一個微服務後發起遠程調用
搭建Eeruka
1.創建項目,引入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-服務發現
在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搭建流程內容請搜索LevelAH以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持LevelAH!
推薦閱讀:
- SpringCloud Eureka的使用教程
- SpringCloud實現Eureka服務註冊與發現
- 深入學習Spring Cloud-Ribbon
- SpringCloud Eureka服務治理之服務註冊服務發現
- SpringCloud 分佈式微服務架構操作步驟