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

SpringCloud服務的發(fā)現(xiàn)與調(diào)用詳解

 更新時間:2022年07月16日 14:14:36   作者:_時光煮雨  
在Java微服務越來越火的今天。幾乎什么公司都在搞微服務。而使用的比較多的就是Spring?Cloud技術棧。今天就來研究一下Spring?Cloud中服務發(fā)現(xiàn)與調(diào)用的基本原理

相關推薦

上一章:Eureka注冊中心

前言

上一章中,我們介紹了Eureka注冊中心及集群的搭建,這一節(jié)將介紹服務的發(fā)現(xiàn)和調(diào)用。注意,這個時候我們只有注冊中心,并沒有引入其他的組件,所以需要使用SpringCloud原生態(tài)的服務發(fā)現(xiàn)和調(diào)用的方式實現(xiàn),循序漸進的帶你走入微服務的世界。

上篇文章我們已經(jīng)創(chuàng)建好了注冊中心,這次我們需要創(chuàng)建一個服務提供者(provider)和一個服務消費者(consumer)兩個項目。

一、服務提供者

  • 新建Maven項目provider
  • 引入項目依賴
    <parent>
        <groupId>com.cxy965</groupId>
        <artifactId>parent</artifactId>
        <version>1.0-SNAPSHOT</version>
        <relativePath>../parent/pom.xml</relativePath>
    </parent>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
    </dependencies>

新建配置文件application.yml

server:
  port: 8002
spring:
  application:
    name: provider
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8001/eureka/
    fetch-registry: true

創(chuàng)建啟動類和服務接口,為了簡便,暫時將服務接口放在了啟動類,實際項目中,最好還是要放在controller中。

@EnableEurekaClient
@SpringBootApplication
@RestController
public class ProviderApplication {
    public static void main(String[] args) {
        SpringApplication.run(ProviderApplication.class, args);
    }
    @GetMapping("/hello")
    public String hello(String name) {
       return "Hello "+name;
    }
}

啟動驗證一下,可以正常返回。

二、服務消費者

  • 參考provider項目創(chuàng)建consumer項目
  • 修改配置文件中的端口和應用名稱為8003、consumer
  • 創(chuàng)建啟動類和服務消費代碼
@EnableEurekaClient
@SpringBootApplication
@RestController
public class ConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class, args);
    }
    @Bean
    RestTemplate restTemplate() {
        return new RestTemplate();
    }
    @Autowired
    DiscoveryClient discoveryClient;
    @Autowired
    RestTemplate restTemplate;
    @GetMapping("/hello")
    public String hello(String name) {
        List<ServiceInstance> list = discoveryClient.getInstances("provider");
        ServiceInstance instance = list.get(0);
        String host = instance.getHost();
        int port = instance.getPort();
        String returnInfo = restTemplate.getForObject("http://" + host + ":" + port + "/hello?name={1}", String.class, name);
        return returnInfo;
    }
}

啟動驗證一下

可以看到,我們調(diào)用8003消費者服務,消費者服務又調(diào)用了8002服務提供者的接口,并正確返回了結果。

總結

我們來分析一下消費者代碼,我們先創(chuàng)建了一個RestTemplate Bean實例,然后注入進來,同時注入discoveryClient對象。

在接口中,通過discoveryClient.getInstances("provider")方法獲取注冊到注冊中心中的所有provider服務信息ServiceInstance集合,ServiceInstance其實是一個接口,真正的實現(xiàn)類是EurekaServiceInstance,通過查看EurekaServiceInstance的源碼,我們發(fā)現(xiàn)它里面包含了注冊中心中各服務的豐富的詳細信息(如主機地址、端口號、實例id,應用名稱、應用組名稱等)。

我們先拿到第一個服務提供者的的ip和端口(集群部署情況下,可能會有多個實例),然后通過調(diào)用restTemplate.getForObject()方法進行接口的調(diào)用并獲取返回信息。

這樣就通過原生態(tài)的方式實現(xiàn)了服務的發(fā)現(xiàn)和調(diào)用。

拿到第一個實例進行接口的調(diào)用,顯然沒有達到部署多服務實例的目的,下一篇文章將帶你實現(xiàn)一個自定義的負載均衡器,一起期待吧!

到此這篇關于SpringCloud服務的發(fā)現(xiàn)與調(diào)用詳解的文章就介紹到這了,更多相關SpringCloud服務內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java?17的一些新特性介紹

    Java?17的一些新特性介紹

    這篇文章主要介紹了Java?17的一些新特性介紹,Java添加了許多Java開發(fā)人員渴望的特性和改進,下文就來學習一下這些特性吧,需要的朋友可以參考一下
    2022-04-04
  • 詳解SpringBoot集成消息隊列的案例應用

    詳解SpringBoot集成消息隊列的案例應用

    Message?Queue又名消息隊列,是一種異步通訊的中間件??梢岳斫鉃猷]局,發(fā)送者將消息投遞到郵局,然后郵局幫我們發(fā)送給具體的接收者,具體發(fā)送過程和時間與我們無關。?消息隊列是分布式系統(tǒng)中重要的組件,消息隊列主要解決了應用耦合、異步處理、流量削鋒等問題
    2022-04-04
  • SpringBoot參數(shù)校驗與國際化使用教程

    SpringBoot參數(shù)校驗與國際化使用教程

    這篇文章主要給大家介紹了關于SpringBoot參數(shù)校驗與國際化使用教程的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • java用LocalDateTime類獲取當天時間、前一天時間及本周/本月的開始和結束時間

    java用LocalDateTime類獲取當天時間、前一天時間及本周/本月的開始和結束時間

    這篇文章主要給大家介紹了關于java使用LocalDateTime類獲取當天時間、前一天時間及本周/本月的開始和結束時間的相關資料,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下
    2023-08-08
  • Spring Data Redis對象緩存序列化問題解決

    Spring Data Redis對象緩存序列化問題解決

    相信在項目中,你一定是經(jīng)常使用Redis,在使用時,有沒有遇到同我一樣,對象緩存序列化問題的呢,本文主要介紹了Spring Data Redis對象緩存序列化問題解決,感興趣的可以了解一下
    2024-01-01
  • Java使用Redis的方法實例分析

    Java使用Redis的方法實例分析

    這篇文章主要介紹了Java使用Redis的方法,接合實例形式分析了相關redis驅動包安裝、java連接redis服務器、數(shù)據(jù)存儲、讀取等相關操作技巧,需要的朋友可以參考下
    2018-05-05
  • Java8中的LocalDateTime和Date一些時間操作方法

    Java8中的LocalDateTime和Date一些時間操作方法

    這篇文章主要介紹了Java8中的LocalDateTime和Date一些時間操作方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • Java通俗易懂系列設計模式之策略模式

    Java通俗易懂系列設計模式之策略模式

    這篇文章主要介紹了Java通俗易懂系列設計模式之策略模式,對設計模式感興趣的同學,一定要看一下
    2021-04-04
  • IDEA?mybatis?Mapper.xml報紅的最新解決辦法

    IDEA?mybatis?Mapper.xml報紅的最新解決辦法

    這篇文章主要介紹了IDEA?mybatis?Mapper.xml報紅的解決辦法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • SrpingDruid數(shù)據(jù)源加密數(shù)據(jù)庫密碼的示例代碼

    SrpingDruid數(shù)據(jù)源加密數(shù)據(jù)庫密碼的示例代碼

    本篇文章主要介紹了SrpingDruid數(shù)據(jù)源加密數(shù)據(jù)庫密碼的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10

最新評論