加入收藏 | 设为首页 | 会员中心 | 我要投稿 核心网 (https://www.hxwgxz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

负载均衡常见算法,你知道几个?

发布时间:2019-08-29 23:12:48 所属栏目:建站 来源:佚名
导读:冷备与热备 冷备份(cool standby),指配备平时不运行的备用设备,当运行设备发生故障时,使用备用设备替换。 热备份(hot standby),指在设备运行的同时运行备用设备,当运行设备发生故障时,能够自动替换备用设备。 fail-over与fail-back fail-over,在空

刚刚有说道过,不同的服务器性能不同,所以不能一概而论,需要给性能低的服务器给比较低的权重,性能高的给跟高的权重,代码如下:

  1. public class BalanceServer { 
  2.  public static Map<String, Integer> serverMap = new HashMap<String, Integer>(); 
  3.  public static int pos = 0; 
  4.  static { 
  5.  serverMap.put("192.168.0.1", 1); 
  6.  serverMap.put("192.168.0.2", 1); 
  7.  serverMap.put("192.168.0.3", 4); 
  8.  serverMap.put("192.168.0.4", 3); 
  9.  serverMap.put("192.168.0.5", 3); 
  10.  serverMap.put("192.168.0.6", 2); 
  11.  } 
  12.  public static String getServer() { 
  13.  Set<String> keySet = serverMap.keySet(); 
  14.  Iterator<String> it = keySet.iterator(); 
  15.  List<String> servers = new ArrayList<String>(); 
  16.  while (it.hasNext()) { 
  17.  String server = it.next(); 
  18.  Integer weight = serverMap.get(server); 
  19.  for (int i = 0; i < weight; i++) { 
  20.  servers.add(server); 
  21.  } 
  22.  } 
  23.  String server = null; 
  24.  if (pos >= servers.size()) { 
  25.  pos = 0; 
  26.  } 
  27.  server = servers.get(pos); 
  28.  pos++; 
  29.  return server; 
  30.  } 
  31.  public static void main(String[] args) { 
  32.  for(int i=0;i<14;i++){ 
  33.  System.out.println(BalanceServer.getServer()); 
  34.  } 
  35. 35 } 
  36. 36} 

5.加权随机法

与加权轮询法类似,加权随机法也是根据后端服务器不同的配置和负载情况来配置不同的权重。不同的是,它是按照权重来随机选择服务器的,而不是顺序。加权随机法的代码实现如下:

  1. public class WeightRandom 
  2.  public static String getServer() 
  3.  { 
  4.  // 重建一个Map,避免服务器的上下线导致的并发问题 
  5.  Map<String, Integer> serverMap =  
  6.  new HashMap<String, Integer>(); 
  7.  serverMap.putAll(IpMap.serverWeightMap); 
  8.  // 取得Ip地址List 
  9.  Set<String> keySet = serverMap.keySet(); 
  10.  Iterator<String> iterator = keySet.iterator(); 
  11.  List<String> serverList = new ArrayList<String>(); 
  12.  while (iterator.hasNext()) 
  13.  { 
  14.  String server = iterator.next(); 
  15.  int weight = serverMap.get(server); 
  16.  for (int i = 0; i < weight; i++) 
  17.  serverList.add(server); 
  18.  } 
  19.  java.util.Random random = new java.util.Random(); 
  20.  int randomPos = random.nextInt(serverList.size()); 
  21.  return serverList.get(randomPos); 
  22.  } 

(编辑:核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读