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

Spring Cloud EureKa Ribbon 服務注冊發(fā)現(xiàn)與調(diào)用

 更新時間:2018年02月26日 09:14:59   作者:Sam哥哥  
這篇文章主要介紹了Spring Cloud EureKa Ribbon 服務注冊發(fā)現(xiàn)與調(diào)用,小編覺得挺不錯的,現(xià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來管理微服務,微服務可以注冊到eureka中。

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

修改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為我們生成的啟動類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/

可以看到如下界面:

可以看到暫時還沒有服務注冊上來。到此,一個簡單的微服務注冊中心就構(gòu)建完了。

編寫微服務userservice

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

注意這次要勾選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)建一個rest full的微服務接口。

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.";
  }
}

運行UserApplication后,再次訪問http://localhost:8881/

會發(fā)現(xiàn)user這個服務已經(jīng)注冊上來了。

編寫微服務order

接下來,我們再構(gòu)建一個訂單的微服務,并訪問user這個微服務中的接口。

依然使用Spring Initialzr 來構(gòu)建一個新工程。user這個微服務是可以部署到多臺機器上的??蛻舳嗽谠L問這個服務的時候,請求可以路由到任何一臺部署了user服務的機器。因此客戶端需要使用一個路由算法來調(diào)度user這個服務。在Spring Cloud中,可以使用Ribbon組件來做客戶端路由。Ribbon內(nèi)部會去服務注冊中心獲取服務列表的,以便調(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注解。

編寫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();
  }
}

運行OrderApplication后,訪問http://localhost:8881/

會發(fā)現(xiàn)order這個服務也被注冊到注冊中心了。

接下來我們訪問OrderController中的getOrderUser 方法,觸發(fā)調(diào)用UserControllergetUser方法。
在瀏覽器中輸入:http://localhost:8883/getOrderUser

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

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

最新評論