zoukankan      html  css  js  c++  java
  • IFB上挂载NETEM

    转发虚拟网卡的ingress

    建立虚拟网卡的ingress转发到ifb0(每一个Pod):

    tc qdisc add dev calixxxxxxxxxxx ingress
    tc filter add dev calixxxxxxxxxxx parent ffff: protocol ip prio 10 u32 match u32 0 0 flowid 1:1 action mirred egress redirect dev ifb0
    

    建立ifb0的根队列htb(每一个Node):

    tc qdisc add dev ifb0 root handle 1: htb default 0
    

    为x号Pod建立一个类1:x(每一个Pod):

    tc class add dev ifb0 parent 1: classid 1:x htb rate 100mbps
    

    为Podx的IPx.x.x.x建立一个过滤器,使来自该Podx的流量进入子类1:x(每一个Pod):

    tc filter add dev ifb0 protocol ip parent 1:0 prio 1 u32 match ip src x.x.x.x flowid 1:x
    

    为每一个类建立一个netem队列x+1:1(每一个Pod)

    tc qdisc add dev ifb0 parent 1:1 handle x+1: netem delay 100ms
    

    转发虚拟网卡的egress

    为虚拟网卡的egress建立HTB队列1:(每一个Pod)

    tc qdisc add dev calixxxxxxxxxxx root handle 1: htb default 1
    

    为HTB建立子类1:1(每一个Pod)

    tc class add dev calix parent 1: classid 1:1 htb rate 100mbps
    

    为子类建立队列(每一个Pod)

    tc qdisc add dev calix parent 1:1 pfifo limit 1600
    

    转发到IFB1(每一个Pod)

    tc filter add dev calix parent 1: proto ip prio 1 u32 match u32 0 0 flowid 1:1 action mirred egress redirect dev ifb1
    

    建立ifb1的根队列htb(每一个Node):

    tc qdisc add dev ifb1 root handle 1: htb default 0
    

    为x号Pod建立一个类1:x(每一个Pod):

    tc class add dev ifb1 parent 1: classid 1:x htb rate 100mbps
    

    为Podx的IPx.x.x.x建立一个过滤器,使来自该Podx的流量进入子类1:x(每一个Pod):

    tc filter add dev ifb1 protocol ip parent 1:0 prio 1 u32 match ip src x.x.x.x flowid 1:x
    

    为每一个类建立一个netem队列x+1:1(每一个Pod)

    tc qdisc add dev ifb1 parent 1:1 handle x+1: netem delay 100ms
    
  • 相关阅读:
    VC++6.0程序打开文件内存错误解决方法
    c++ vc6.0环境sp6补丁
    Net 应用程序如何在32位操作系统下申请超过2G的内存
    DataTable 排序
    VC UI 界面库
    让CSS兼容IE和Firefox的技巧集合
    两句CSS属性让点击图片链接时的虚线框消失
    一个常用的表单文本框input输入提示
    Css优先级分析
    清除浮动四种方法
  • 原文地址:https://www.cnblogs.com/bforever/p/10601211.html
Copyright © 2011-2022 走看看