负载均衡加权轮询算法

随机数加权轮询算法

java 复制代码
public int select() {
        int[] weights = {10, 20, 50};
        int totalWeight = weights[0] + weights[1] + weights[2];
        // 取随机数
        int offset = ThreadLocalRandom.current().nextInt(totalWeight);
        for (int i = 0; i < weights.length; i++) {
            offset -= weights[i];
            if (offset < 0) {
                return i;
            }
        }
        return -1;
    }

平滑加权轮询算法

java 复制代码
int[] weights = {10, 20, 50};   // 节点权重
    int totalWeight = weights[0] + weights[1] + weights[2]; // 总权重
    int[] current = new int[]{10, 20, 50};  // 初始化当前权重

    public int select() {
        int maxCurrent = -1, selected = -1;
        // 遍历所有节点,找到当前权重最大的节点
        for (int i = 0; i < weights.length; i++) {
            // 重新计算当前权重
            current[i] += weights[i];
            int cur = current[i];
            if (cur > maxCurrent) {
                maxCurrent = cur;
                selected = i;
            }
        }
        // 被选中的节点减去总权重
        current[selected] -= totalWeight;
        return selected;
    }
相关推荐
wefg15 分钟前
【数据结构】unordered 系列容器底层结构和封装
数据结构·算法·哈希算法
从零点12 分钟前
插补算法(逐点比较法)+PWM配置操作
算法
SongYuLong的博客14 分钟前
Linux开源代码汇总
linux·运维·服务器
铭哥的编程日记18 分钟前
【Linux网络】应用层协议HTTP
linux·运维·http
SakitamaX22 分钟前
nginx
运维·nginx
DARLING Zero two♡24 分钟前
【优选算法】LinkedList-Concatenate:链表的算法之契
数据结构·c++·算法·链表
Moonbit35 分钟前
MoonBit Pearls Vol.14:哈希表避坑指南
后端·算法·编程语言
杰克尼1 小时前
120. 三角形最小路径和
算法
树在风中摇曳1 小时前
C语言动态内存管理:从基础到进阶的完整解析
c语言·开发语言·算法
云飞云共享云桌面1 小时前
三维设计办公资源如何共享集中和安全管控?
运维·服务器·数据库·安全·自动化·制造