Ribbon本地负载均衡

package com.eureakorder.api.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

import java.util.List;
//纯手写ribbon本地负载均衡,如果使用这个本地负载均衡、需要将启动类的负载均衡的注解	@LoadBalanced注释掉
@RestController
public class ExtRibbonController {
	//可以获取注册中心服务上的注册列表
	@Autowired
	private DiscoveryClient discoveryClient;
	@Autowired
	private RestTemplate restTemplate;

	//定义接口请求总数(此处定义是不安全的,要用原子性)
	private int reqCount=1;
	@RequestMapping("/getRibbon")
	public String ribbonMember(){
		String instanceUrl=getInstance()+"/getMember";
		System.out.println("instanceUrl:"+instanceUrl);
		//2、使用rest方式发送请求
		String result=restTemplate.getForObject(instanceUrl,String.class);
		return result;
	}

	public String getInstance(){
		//1、获取对应服务器的远程调用地址(接口地址可能是个集群,所以返回结果集是个集合)
		List<ServiceInstance> instances=discoveryClient.getInstances("eureka-member");
		if(instances==null||instances.size()<1){
			return "";
		}
		//获取服务器集群个数
		int instanceSize=instances.size();
		int serviceIndex=reqCount % instanceSize;
		reqCount++;
		return instances.get(serviceIndex).getUri().toString();
	}

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值