溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

springCloud項目搭建流程是什么

發(fā)布時間:2022-05-11 10:22:23 來源:億速云 閱讀:176 作者:zzz 欄目:開發(fā)技術(shù)

本篇內(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注冊中心

springCloud項目搭建流程是什么

內(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ù)學習!

向AI問一下細節(jié)

免責聲明:本站發(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)容。

AI