SpringBoot+SpringCloud+Ribbon实现负载均衡

1

SpringBoot+SpringCloud+Ribbon实现负载均衡_第1张图片

 

2注册中心配置如下:

server:

  port: 2020



eureka:

  instance:

    hostname: localhost



  client:

    fetch-registry: false

    register-with-eureka: false

    service-url:

      defaultZone:  http://${
    eureka.instance.hostname}:${
    server.port}/eureka/

3服务消费者配置如下:

server:

  port: 8082



spring:

  application:

    name: demo_web



eureka:

  client:

    fetch-registry: true    #是否eureka取各微服地址

    register-with-eureka: true    #是否注eureka器

    service-url:

      defaultZone: http://localhost:2020/eureka/

controller如下:

@RestController

@RequestMapping("user")

public class UserController {



    @Autowired

    private UserService userService;



    @RequestMapping("getUserInfo")

    public String getUserInfo(String account, String pwd) {

        System.out.println("务调用者demo_web="+account);

        return userService.getUserInfo(account, pwd);

    }

}

Service如下:

@Service

public class UserService {



    @Autowired

    private RestTemplate restTemplate;



    public String getUserInfo(String account,String pwd) {

        System.out.println("demoservice方法");

        //提供者的用名称进访问

        return restTemplate.getForObject("http://USER-CLIENT/adminControl/getJsp?account="+account+"&pwd="+pwd, String.class);

    }

}

Application如下:

@SpringBootApplication

@EnableEurekaClient

public class DemoWebApplication {



    @Bean

    @LoadBalanced

    public RestTemplate restTemplate() {

        System.out.println("demowebrestTemplate");

        return new RestTemplate();

    }

    

    public static void main(String[] args) {

        System.out.println("demowebmain方法");

        SpringApplication.run(DemoWebApplication.class, args);

    }



}

 

3、两个服务提供者的内容完全一致,只是配置的端口不一致:(一个8080,一个8085)

server:

  port: 8080



spring:

  datasource:

    driver-class-name: com.mysql.jdbc.Driver

    username: root

    password: root

    type: com.alibaba.druid.pool.DruidDataSource

    url: jdbc:mysql://localhost:3306/jx191222

  application:

    name: user-client



mybatis:

  mapper-locations: classpath:mapper/*.xml

  config-location: classpath:SqlMapConfig.xml



eureka:

  client:

    fetch-registry: true   #是否eureka取各微服地址

    register-with-eureka: true  #是否注eureka器

    service-url:

      defaultZone:  http://localhost:2020/eureka

 

4、打开注册中心:

SpringBoot+SpringCloud+Ribbon实现负载均衡_第2张图片

 

5、打开服务消费者端口:

 

6、好像是内部的时间策略机制会自动分配访问哪个端口,实现负载平衡:

SpringBoot+SpringCloud+Ribbon实现负载均衡_第3张图片

SpringBoot+SpringCloud+Ribbon实现负载均衡_第4张图片

你可能感兴趣的:(SpringCloud,ribbon,spring,boot)