溫馨提示×

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

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

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

發(fā)布時(shí)間:2021-08-06 09:19:07 來(lái)源:億速云 閱讀:97 作者:小新 欄目:編程語(yǔ)言

這篇文章主要介紹Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

概述

用一個(gè)簡(jiǎn)單的例子演示Spring Cloud中EureKa和Ribbon的基本用法。

版本和環(huán)境

  1. IDEA

  2. Spring Boot 1.5.·0

  3. JDK 1.8

  4. Maven 3

構(gòu)建eureka server

在Spring Cloud,可以使用eureka來(lái)管理微服務(wù),微服務(wù)可以注冊(cè)到eureka中。

首先可以用IDEA的Spring Initialzr 來(lái)創(chuàng)建eureka server注冊(cè)中心。

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

修改application.properties文件,添加如下內(nèi)容

spring.application.name=eureka-server 
eureka.instance.hostname=localhost 
eureka.client.register-with-eureka=false 
eureka.client.fetch-registry=false 
server.port=8881

在Spring Boot為我們生成的啟動(dòng)類ServerApplication 中加入@EnableEurekaServer 注解

package com.springcloud.eureka;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@EnableEurekaServer
@SpringBootApplication
public class ServerApplication {

  public static void main(String[] args) {
    SpringApplication.run(ServerApplication.class, args);
  }
}

在瀏覽器中輸入http://localhost:8881/

可以看到如下界面:

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

可以看到暫時(shí)還沒(méi)有服務(wù)注冊(cè)上來(lái)。到此,一個(gè)簡(jiǎn)單的微服務(wù)注冊(cè)中心就構(gòu)建完了。

編寫(xiě)微服務(wù)userservice

接下來(lái)用rest構(gòu)建一個(gè)微服務(wù)接口,并注冊(cè)到注冊(cè)中心上去。依然使用Spring Initialzr 來(lái)構(gòu)建一個(gè)新的工程。使用方式跟上面的一樣。

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

注意這次要勾選Eureka Discovery 組件。而不是Eureka Server 。

修改application.properties文件,添加如下內(nèi)容:

spring.application.name=user 
server.port=8882 
eureka.client.service-url.defaultZone=http://localhost:8881/eureka/

Spring Boot 為我們生成的UserApplication 類中使用@EnableDiscoveryClient 注解。

package com.springcloud;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@EnableDiscoveryClient
@SpringBootApplication
public class UserApplication {

  public static void main(String[] args) {
    SpringApplication.run(UserApplication.class, args);
  }
}

創(chuàng)建一個(gè)rest full的微服務(wù)接口。

package com.springcloud;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class UserController {

  @GetMapping("/getUser")
  public String getUser() {
    return "I am user list.";
  }
}

運(yùn)行UserApplication后,再次訪問(wèn)http://localhost:8881/

會(huì)發(fā)現(xiàn)user這個(gè)服務(wù)已經(jīng)注冊(cè)上來(lái)了。

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

編寫(xiě)微服務(wù)order

接下來(lái),我們?cè)贅?gòu)建一個(gè)訂單的微服務(wù),并訪問(wèn)user這個(gè)微服務(wù)中的接口。

依然使用Spring Initialzr 來(lái)構(gòu)建一個(gè)新工程。user這個(gè)微服務(wù)是可以部署到多臺(tái)機(jī)器上的。客戶端在訪問(wèn)這個(gè)服務(wù)的時(shí)候,請(qǐng)求可以路由到任何一臺(tái)部署了user服務(wù)的機(jī)器。因此客戶端需要使用一個(gè)路由算法來(lái)調(diào)度user這個(gè)服務(wù)。在Spring Cloud中,可以使用Ribbon組件來(lái)做客戶端路由。Ribbon內(nèi)部會(huì)去服務(wù)注冊(cè)中心獲取服務(wù)列表的,以便調(diào)用對(duì)應(yīng)的服務(wù)。

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

這次除了勾選Eureka Discovery 組件。還需要勾選Ribbon

修改application.properties文件,添加如下內(nèi)容:

spring.application.name=order 
server.port=8883 
eureka.client.service-url.defaultZone=http://localhost:8881/eureka/

Spring Boot 為我們生成的OrderApplication類中增加如下配置。

package com.springboot;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
@EnableDiscoveryClient
@SpringBootApplication
public class OrderApplication {

  @Bean
  @LoadBalanced
  RestTemplate restTemplate() {
    return new RestTemplate();
  }

  public static void main(String[] args) {
    SpringApplication.run(OrderApplication.class, args);
  }
}

由于使用了Ribbon,這里需要使用@LoadBalanced注解。

編寫(xiě)OrderController。

package com.springboot;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

@RestController
public class OrderController {
  @Autowired
  private RestTemplate restTemplate;

  @GetMapping("/getOrderUser")
  public String getOrderUser() {
    return restTemplate.getForEntity("http://user/getUser",String.class).getBody();
  }
}

運(yùn)行OrderApplication后,訪問(wèn)http://localhost:8881/

會(huì)發(fā)現(xiàn)order這個(gè)服務(wù)也被注冊(cè)到注冊(cè)中心了。

Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析

接下來(lái)我們?cè)L問(wèn)OrderController中的getOrderUser 方法,觸發(fā)調(diào)用UserControllergetUser方法。
在瀏覽器中輸入:http://localhost:8883/getOrderUser

可以看到返回了:I am user list.

以上是“Spring Cloud EureKa Ribbon中服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI