ribbon负载均衡

自定义ribbon代码:
引入jar包

 <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
        </dependency>

yml

server:
  port: 8085
spring:
  application:
    name: client

#eureka:
#  client:
#    service-url:
#      defaultZone: http://localhost:10000/eureka
eureka:
  client:
    enabled: false
#定义一个serverList给我们做负载均衡
##格式{serviceId}:ribbon:listOfservers
hello-server:
  ribbon:
    listOfServers: localhost:8082,localhost:8083

@SpringBootApplication
@RestController
@RibbonClients(
        @RibbonClient(value = "hello-server")
)
public class CosumerApplication {



    @Autowired
    RestTemplate restTemplate;

    @Autowired
    LoadBalancerClient loadBalancerClient;


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

    @GetMapping("/index")
    public String index(){
        ServiceInstance serviceInstance = loadBalancerClient.choose("hello-server");
        String ip = serviceInstance.getHost();
        int port = serviceInstance.getPort();
        return restTemplate.getForObject("http://"+ip+":"+port+"index",String.class,"")+port;
    }

}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容