Eureka集群版之服务注册与发现实战演练

Eureka集群版之服务注册与发现实战演练

  • 整体流程介绍
  • 准备工作
  • EurekaClient增加服务内容
  • 新建EurekaClient消费者
  • 顺序启动服务

整体流程介绍

Eureka集群版之服务注册与发现实战演练_第1张图片

准备工作

  1. EurekaServer集群 搭建地址
  2. EurekaClient(服务提供者)集群 搭建地址

EurekaClient增加服务内容

  1. Eureka Client8011增加Controller业务类

    @RestController
    @Slf4j
    public class TestController {
    
        @Value("${server.port}")
        private String port;
    
        @GetMapping(value = "/eat")
        public String eat(){
            return "吃饭喽!服务端口号是"+port;
        }
    }
    
  2. Eureka Client8012增加Controller业务类

    @RestController
    @Slf4j
    public class TestController {
    
        @Value("${server.port}")
        private String port;
    
        @GetMapping(value = "/eat")
        public String eat(){
            return "吃饭喽!服务端口号是"+port;
        }
    
    
    }
    

新建EurekaClient消费者

  1. 搭建地址

  2. 修改端口号和服务名称

    server:
      port: 80 #端口号
    spring:
      application:
        name: eureka-client-consumption #服务名称(消费者)
    eureka:
      client:
        serviceUrl:
          defaultZone: http://eurekaServer8761.com:8761/eureka/,http://eurekaServer8762.com:8762/eureka/
    
  3. 注入RestTemplate实现远程调用

    @Configuration
    public class BeanConfig {
    
        @Bean
        public RestTemplate getRestTemplate(){
            return new RestTemplate();
        }
    }
    
    
  4. 增加Controller业务类

    @RestController
    @Slf4j
    public class TestController {
    
        /**
         * EUREKA-CLIENT-SERVICE:就是EUREKA-SERVER对外提供的服务名称
         */
        private static final String EUREKA_CLIENT_SERVICE = "http://EUREKA-CLIENT-SERVICE";
    
        @Resource
        private RestTemplate restTemplate;
    
        @GetMapping(value = "/eat")
        public String eat(){
            return restTemplate.getForObject(EUREKA_CLIENT_SERVICE+"/eat",String.class);
        }
    }
    
    

顺序启动服务

  1. 启动EurekaServer集群

  2. 启动EurekaClient(服务提供者)集群

  3. 启动EurekaClient消费者80访问 http://127.0.0.1/eat
    Eureka集群版之服务注册与发现实战演练_第2张图片
    Eureka Server集群没那么智能,因为EUREKA-CLIENT-SERVICE服务名称下有两个服务提供者,它不知道具体找哪个服务

  4. 解决方法:注入RestTemplate的时增加@LoadBalanced注解

@Configuration
public class BeanConfig {

    @Bean
    @LoadBalanced  //开启负载均衡的功能
    public RestTemplate getRestTemplate(){
        return new RestTemplate();
    }
}
  1. 再次访问http://127.0.0.1/eat

Eureka集群版之服务注册与发现实战演练_第3张图片

你可能感兴趣的:(eureka,eureka)