ribbon基于统计学的客户端负载均衡软件

故事扮演 提交于 2020-08-12 11:48:52

众所周知 ribbon 是一款客户端负载均衡软件,今天我添加了一个修饰词, 基于统计学的, 因为  ServerListFilter  和  IRule.choose  都是基于 ServerStats 和ZoneSnapshot等统计信息做出决策的。

 

LoadBalancerStats  作为存储仓库 ,维护了两个Map
volatile Map<String, ZoneStats> zoneStatsMap = new ConcurrentHashMap<String, ZoneStats>();

每个zone的统计信息

volatile Map<String, List<? extends Server>> upServerListZoneMap = new ConcurrentHashMap<String, List<? extends Server>>();

每个zone的up状态的server。

 

内存缓存。。。  将所有ServerStats存于其中。      LocalLoadingCache

private final LoadingCache<Server, ServerStats> serverStatsCache = 
    CacheBuilder.newBuilder()
        .expireAfterAccess(SERVERSTATS_EXPIRE_MINUTES.get(), TimeUnit.MINUTES)
        .removalListener(new RemovalListener<Server, ServerStats>() {
            @Override
            public void onRemoval(RemovalNotification<Server, ServerStats> notification) {
                notification.getValue().close();
            }
        })
        .build(
            new CacheLoader<Server, ServerStats>() {
                public ServerStats load(Server server) {
                    return createServerStats(server);
                }
            });

 

 

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!