日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Ribbon负载均衡策略配置

發布時間:2025/5/22 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Ribbon负载均衡策略配置 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在這里吐槽一句:網上很多文章真是神坑,你不看還好,看了只會問題越來越多,就連之前的問題都沒有解決!!!

不多說了,Ribbon作為后端負載均衡器,比Nginx更注重的是請求分發而不是承擔并發,可以直接感知后臺動態變化來指定分發策略。它一共提供了7種負載均衡策略:

策略名策略聲明策略描述實現說明
BestAvailableRulepublic class BestAvailableRule extends ClientConfigEnabledRoundRobinRule選擇一個最小的并發請求的server逐個考察Server,如果Server被tripped了,則忽略,在選擇其中ActiveRequestsCount最小的server
AvailabilityFilteringRulepublic class AvailabilityFilteringRule extends PredicateBasedRule過濾掉那些因為一直連接失敗的被標記為circuit tripped的后端server,并過濾掉那些高并發的的后端server(active connections 超過配置的閾值)使用一個AvailabilityPredicate來包含過濾server的邏輯,其實就就是檢查status里記錄的各個server的運行狀態
WeightedResponseTimeRulepublic class WeightedResponseTimeRule extends RoundRobinRule根據響應時間分配一個weight,響應時間越長,weight越小,被選中的可能性越低。一個后臺線程定期的從status里面讀取評價響應時間,為每個server計算一個weight。Weight的計算也比較簡單responsetime 減去每個server自己平均的responsetime是server的權重。當剛開始運行,沒有形成status時,使用roubine策略選擇server。
RetryRulepublic class RetryRule extends AbstractLoadBalancerRule對選定的負載均衡策略機上重試機制。在一個配置時間段內當選擇server不成功,則一直嘗試使用subRule的方式選擇一個可用的server
RoundRobinRulepublic class RoundRobinRule extends AbstractLoadBalancerRuleroundRobin方式輪詢選擇server輪詢index,選擇index對應位置的server
RandomRulepublic class RandomRule extends AbstractLoadBalancerRule隨機選擇一個server在index上隨機,選擇index對應位置的server
ZoneAvoidanceRulepublic class ZoneAvoidanceRule extends PredicateBasedRule復合判斷server所在區域的性能和server的可用性選擇server使用ZoneAvoidancePredicate和AvailabilityPredicate來判斷是否選擇某個server,前一個判斷判定一個zone的運行性能是否可用,剔除不可用的zone(的所有server),AvailabilityPredicate用于過濾掉連接數過多的Server。



這里以隨機訪問策略來舉個栗子:

1、ribbon配置文件添加:

service-B.ribbon.NFLoadBalancerRuleClassName=com.netflix.loadbalancer.RandomRule
  • 1
  • 1

其中service-B是我注冊到Eureka的serviceID,一共起了3個示例。

2、main類注冊:

@Bean@LoadBalancedRestTemplate restTemplate() {return new RestTemplate();}@Bean public IRule ribbonRule() { return new RandomRule();//這里配置策略,和配置文件對應 }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

一定記得加第二個注冊,很多文章沒有。里面配具體的策略。

3、Controller:

@RestController public class ConsumerController { @Autowired private RestTemplate restTemplate; @Autowired private LoadBalancerClient loadBalancerClient; @RequestMapping(value = "/add", method = RequestMethod.GET) public String add(@RequestParam Integer a,@RequestParam Integer b) { this.loadBalancerClient.choose("service-B");//隨機訪問策略 return restTemplate.getForEntity("http://service-B/add?a="+a+"&b="+b, String.class).getBody(); } }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

好了,打完收工。

整個工程搭建,請訪問我的github:https://github.com/Lovnx/micro-service

http://blog.csdn.net/rickiyeat/article/details/64918756

?

轉載于:https://www.cnblogs.com/softidea/p/7413397.html

總結

以上是生活随笔為你收集整理的Ribbon负载均衡策略配置的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。