自定义负载均衡策略
本文介绍如何对 org.apache.shenyu.loadbalancer.spi.LoadBalancer
进行自定义扩展。
- 新增一个类
CustomLoadBalancer
,继承org.apache.shenyu.loadbalancer.spi.AbstractLoadBalancer
。
public class CustomLoadBalancer extends AbstractLoadBalancer {
@Override
public Upstream doSelect(final List<Upstream> upstreamList, final String ip) {
// 自定义负载均衡实现逻辑
}
}
- 在
org.apache.shenyu.loadbalancer.spi.LoadBalancer
文件中添加如下内容:
${spi name}=${custom class path}
${spi name}
表示spi
的名称,${custom class path}
表示该类的全限定名。比如:
custom=org.apache.shenyu.loadbalancer.spi.CustomLoadBalancer
- 在
org.apache.shenyu.common.enums.LoadBalanceEnum
类中添加枚举类型:
/**
* Custom load balance enum.
*/
CUSTOM(4, "custom", true),
- 在
Apache ShenYu
网关管理系统 —> 基础配置 —> 字典管理, 找到字典编码为LOAD_BALANCE
,新增一条数据,注意字典名称要为:${spi name}
,图中的示例是custom
。
字典类型:
loadBalance
;字典编码:
LOAD_BALANCE
;字典名称:
${spi name}
,填写自定义spi
的名称;字典值:使用时,下拉框的值,不要和现有的重复;
字典描述或备注信息:描述信息;
排序: 排序;
- 在添加选择器或规则时,就可以使用自定义的匹配方式: