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!

推薦閱讀: