欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springCloud項(xiàng)目搭建流程步驟分解

 更新時(shí)間:2022年05月10日 16:46:25   作者:TimeFriends  
SpringCloud 作為當(dāng)下最為流行的微服務(wù)框架,也越來越多的人去學(xué)習(xí)和使用這個(gè)框架。下面,我將帶大家簡單地認(rèn)識一下 SpringCloud 框架,以及如何來搭建一個(gè) SpringCloud 項(xiàng)目環(huán)境的教程

實(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)文章

  • 詳解Spring AOP的實(shí)現(xiàn)方式

    詳解Spring AOP的實(shí)現(xiàn)方式

    AOP是一種思想,是對某一類事情的集中處理,切面就是指某一類特定的問題,所以AOP可以理解為面向特定方法編程,這篇文章主要介紹了Spring AOP的實(shí)現(xiàn)方式,需要的朋友可以參考下
    2024-02-02
  • Eclipse+Java+Swing+Mysql實(shí)現(xiàn)電影購票系統(tǒng)(詳細(xì)代碼)

    Eclipse+Java+Swing+Mysql實(shí)現(xiàn)電影購票系統(tǒng)(詳細(xì)代碼)

    這篇文章主要介紹了Eclipse+Java+Swing+Mysql實(shí)現(xiàn)電影購票系統(tǒng)并附詳細(xì)的代碼詳解,需要的小伙伴可以參考一下
    2022-01-01
  • Java中AutoCloseable接口使用小結(jié)

    Java中AutoCloseable接口使用小結(jié)

    Java7引入的AutoCloseable接口,用于自動管理資源的關(guān)閉,避免資源泄露,下面就來介紹一下Java中AutoCloseable接口使用,具有一定的參考價(jià)值,感興趣的可以了解一下
    2025-01-01
  • Java 定時(shí)器(Timer)及線程池里使用定時(shí)器實(shí)例代碼

    Java 定時(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腳本小工具

    文章介紹了如何使用Java實(shí)現(xiàn)一個(gè)解析CURL腳本的工具,該工具可以將CURL腳本中的Header解析為KV Map結(jié)構(gòu),獲取URL路徑、請求類型,解析URL參數(shù)列表和Body請求體,感興趣的小伙伴跟著小編一起來看看吧
    2025-02-02
  • Springboot應(yīng)用中Mybatis輸出SQL日志的3種方法代碼示例

    Springboot應(yīng)用中Mybatis輸出SQL日志的3種方法代碼示例

    在前臺請求數(shù)據(jù)的時(shí)候,sql語句一直都是打印到控制臺的,有一個(gè)想法就是想讓它打印到日志里,該如何做呢?這篇文章主要給大家介紹了關(guān)于Springboot應(yīng)用中Mybatis輸出SQL日志的3種方法,需要的朋友可以參考下
    2024-01-01
  • springboot啟動時(shí)沒有日志的原因分析

    springboot啟動時(shí)沒有日志的原因分析

    這篇文章主要介紹了springboot啟動時(shí)沒有日志的原因分析,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • IDEA 快速返回上次查看代碼的位置的方法

    IDEA 快速返回上次查看代碼的位置的方法

    這篇文章主要介紹了IDEA 快速返回上次查看代碼的位置的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 關(guān)于maven打包時(shí)的報(bào)錯(cuò): Return code is: 501 , ReasonPhrase:HTTPS Required

    關(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
  • Java throw和throws使用區(qū)別分析

    Java throw和throws使用區(qū)別分析

    這篇文章主要介紹了Java throw和throws使用區(qū)別分析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05

最新評論