平滑加权轮询算法java实现

实现代码

java 复制代码
   /**
     * 功能描述: 平滑加权轮询算法
     *
     * @author zhang pu
     * @date 11:46 2023/9/22
     */
   public static void smoothnessWeightPollLoadBalance() {
        Server serverA = new Server("127.0.0.1", 5, 0);
        Server serverB = new Server("127.0.0.2", 3, 0);
        Server serverC = new Server("127.0.0.3", 2, 0);
        List<Server> serverList = new ArrayList<>();
        serverList.add(serverA);
        serverList.add(serverB);
        serverList.add(serverC);
        int i = 0;
        //模拟10个请求
        while (i < 10)
        {
            for (Server server : serverList)
            {
                server.setCurrentWeight(server.getCurrentWeight() + server.getWeight());
            }
            Collections.sort(serverList);
            //获取最高实时权重的服务器去执行业务
            Server server = serverList.get(0);
            logger.info("执行业务的服务器ip:{}", server.getIp());
            int sum = serverList.stream().mapToInt(Server::getWeight).sum();
            //取出本轮最大的实时权重 - 所以有服务器固定权重之和
            //减权操作
            server.setCurrentWeight(server.getCurrentWeight() - sum);
            logger.info("所有服务器本轮情况:{}", JSON.toJSONString(serverList));
            //进行下一轮
            i++;
        }
    }

实体

java 复制代码
/**
 * @Auther: ZHANG PU
 * @Date: 2023/9/22 13:05
 * @Description:
 */
public class Server implements Comparable {

    /**
     * 服务器ip
     */
    private String ip;
    /**
     * 固定权重
     */
    private int weight;
    /**
     * 动态实时权重
     */
    private int currentWeight;

    public Server() {
    }

    public Server(String ip, int weight, int currentWeight) {
        this.ip = ip;
        this.weight = weight;
        this.currentWeight = currentWeight;
    }

    public String getIp() {
        return ip;
    }

    public void setIp(String ip) {
        this.ip = ip;
    }

    public int getWeight() {
        return weight;
    }

    public void setWeight(int weight) {
        this.weight = weight;
    }

    public int getCurrentWeight() {
        return currentWeight;
    }

    public void setCurrentWeight(int currentWeight) {
        this.currentWeight = currentWeight;
    }

    @Override
    public int compareTo(Object o) {
        return ((Server) o).getCurrentWeight() - this.currentWeight;
    }
}

运行结果

相关推荐
编码追梦人21 小时前
基于 STM32 的智能语音唤醒与关键词识别系统设计 —— 从硬件集成到算法实现
stm32·算法·struts
我狸才不是赔钱货21 小时前
Python的“环境之殇”:从Venv到Conda的终极抉择
开发语言·python·conda
努力进修21 小时前
Rust 语言入门基础教程:从环境搭建到 Cargo 工具链
开发语言·后端·rust
摇滚侠1 天前
Spring Boot3零基础教程,SpringApplication 自定义 banner,笔记54
java·spring boot·笔记
青云交1 天前
Java 大视界 -- Java 大数据机器学习模型在游戏用户行为分析与游戏平衡优化中的应用
java·大数据·机器学习·数据存储·模型构建·游戏用户行为分析·游戏平衡优化
循着风1 天前
二叉树的多种遍历方式
数据结构·算法
暗武逢天1 天前
Java导出写入固定Excel模板数据
java·导出数据·easyexcel·excel固定模板导出
摇滚侠1 天前
Spring Boot3零基础教程,KafkaTemplate 发送消息,笔记77
java·spring boot·笔记·后端·kafka
杯莫停丶1 天前
设计模式之:模板模式
开发语言·设计模式
开发者小天1 天前
调整为 dart-sass 支持的语法,将深度选择器/deep/调整为::v-deep
开发语言·前端·javascript·vue.js·uni-app·sass·1024程序员节