ribbon设置权重_扩展ribbon-支持nacos权重负载均衡

博客主要介绍了Ribbon设置权重的相关内容,给出了Java配置代码。定义了NacosWeightedRule类扩展Ribbon以支持Nacos权重负载均衡,还创建了RibbonConfig类配置规则,同时提到Hoxton会有替代实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

设置权重

java配置

package com.java.sa.content.config;

import com.alibaba.nacos.api.exception.NacosException;

import com.alibaba.nacos.api.naming.pojo.Instance;

import com.netflix.client.config.IClientConfig;

import com.netflix.loadbalancer.AbstractLoadBalancerRule;

import com.netflix.loadbalancer.BaseLoadBalancer;

import com.netflix.loadbalancer.Server;

import lombok.extern.slf4j.Slf4j;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.cloud.alibaba.nacos.NacosDiscoveryProperties;

import org.springframework.cloud.alibaba.nacos.ribbon.NacosServer;

/**

* @author jiangli

* @since 2020/2/9 11:30

* 扩展ribbon-支持nacos权重负载均衡

*/

@Slf4j

public class NacosWeightedRule extends AbstractLoadBalancerRule {

@Autowired

private NacosDiscoveryProperties discoveryProperties;

@Override

public Server choose(Object key) {

BaseLoadBalancer loadBalancer = (BaseLoadBalancer) getLoadBalancer();

String name = loadBalancer.getName();

try {

Instance instance = discoveryProperties.namingServiceInstance().selectOneHealthyInstance(name);

// log.info("选中的instance = {}", instance);

// instance转server

return new NacosServer(instance);

} catch (NacosException e) {

log.error("发生异常", e);

return null;

}

}

@Override

public void initWithNiwsConfig(IClientConfig iClientConfig) {

}

}

package com.java.sa.content.config;

import com.netflix.loadbalancer.IRule;

import org.springframework.context.annotation.Bean;

import org.springframework.context.annotation.Configuration;

/**

* @author jiangli

* @since 2020/2/9 12:16

*/

@Configuration

public class RibbonConfig {

@Bean

public IRule ribbonRule() {

return new NacosWeightedRule();

}

}

Hoxton就会有替代的实现

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值