Ribbion之手写轮询算法

本文分享了如何在SpringCloud Ribbon中自定义LoadBalancer,通过原子Integer实现轮询服务实例的简单手写轮询算法。通过getAndIncrement方法保证并发安全,适用于学习微服务负载均衡原理。

最近在系统的学习SpringCloud,发现视频中有一小段代码,很不错,分享给大家。

Ribbion之手写轮询算法

public interface LoadBalancer{
	ServiceInstance instances(List<ServiceInstance> serviceInstances);
}

@Component
public class MyLB implements LoadBalancer{
	private AtomicInteger atomicInteger = new AtomicInteger(0);
	
	public final int getAndIncrement(){
		int current;
		int next;
		
		do{
			current = this.atomicInteger.get();
			next = current >= 2147483647 ? 0 :current + 1;
		}while(!this.atomicInteger.compareAndSet(current,next));
		return next;
	}
	
	@override
	public ServiceInstance instances(List<ServiceInstance> serviceInstances){
		int index = getAndIncrement()% serviceInstances.size();
		return serviceInstances.get(index);
	}
}

 

往期精彩内容:

Java知识体系总结(2021版)

超详细的springBoot学习笔记

Java多线程基础知识总结(绝对经典)

Java面试题总结(附答案)

Vue基础知识总结(绝对经典)

常见数据结构与算法整理总结

 

### 使用替代方案替换Spring Cloud Ribbon进行负载均衡和服务路由 #### 替代方案的选择 随着技术的发展,Spring官方推出了更现代化的解决方案——`Spring Cloud LoadBalancer`。该组件不仅提供了与Ribbon相似的功能,还具有更好的集成性和性能表现[^3]。 #### 配置Spring Cloud Gateway配合LoadBalancer使用 为了实现这一目标,在构建微服务架构时可以采用如下方式配置: 1. **引入依赖** 更新项目的`pom.xml`文件,移除旧版Ribbon相关依赖并加入最新的`spring-cloud-starter-loadbalancer`包。 ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-loadbalancer</artifactId> </dependency> ``` 2. **修改应用程序属性** 对于想要启用自动配置的服务发现机制的应用程序来说,只需简单设置以下参数即可开启此功能: ```yaml spring: cloud: loadbalancer: ribbon: enabled: false # 关闭对Ribbon的支持 ``` 3. **编写自定义过滤器或控制器逻辑** 当涉及到具体的业务场景下处理请求转发等问题时,则可以通过创建相应的Filter类或者Controller方法来完成特定需求下的路径映射及流量分配操作。下面给出一段简单的例子展示如何利用RestTemplate发起带有负载均衡特性的HTTP GET请求: ```java @RestController public class HelloController { private final RestTemplate restTemplate; @Autowired public HelloController(RestTemplateBuilder restTemplateBuilder){ this.restTemplate = restTemplateBuilder.build(); } @GetMapping("/call-service") public String callService(){ return restTemplate.getForObject("http://SERVICE_NAME/hello",String.class); } } ``` 此处需要注意的是,“SERVICE_NAME”应被实际存在的服务名称所取代,并且确保Eureka或其他形式的服务注册中心正常运行以便能够解析对应的服务地址列表[^4]。 4. **高级特性定制化开发** 如果希望进一步优化系统的灵活性和可维护性,还可以考虑通过继承`AbstractLoadBalancerRule`来自定义一套全新的算法规则应用于不同的上下文中;亦或是借助Spring AOP面向切面编程的思想围绕着核心流程编织额外的日志记录、权限验证等功能模块[^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哪 吒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值