networking - 在 Docker 容器接口(interface)上应用 NetEM WAN 延迟

标签 networking docker iproute

我想对 Docker 容器的导出流量应用 NetEm 延迟。通常,我运行:

# /sbin/tc qdisc add dev $INTERFACE root netem delay ${DELAY}ms

问题是我不知道容器连接到的接口(interface)。

例如,我正在运行以下容器:

docker run --rm -it alpine /bin/sh

然后我 ping 8.8.8.8:

/ # ping 8.8.8.8
PING 8.8.8.8 (8.8.8.8): 56 data bytes
64 bytes from 8.8.8.8: seq=0 ttl=44 time=39.783 ms
64 bytes from 8.8.8.8: seq=1 ttl=44 time=39.694 ms

我想要做的是从我的主机添加 NetEm 规则,并查看 ping 时间的变化。

如果我运行 ifconfig,我会看到存在多个虚拟以太网接口(interface)(因为其他容器正在运行),但我不知道连接到哪一个我感兴趣的容器:

# ifconfig
veth09fa1c5 Link encap:Ethernet  HWaddr 96:73:c9:15:93:b8  
          inet6 addr: fe80::9473:c9ff:fe15:93b8/64 Scope:Link
          .....

vethf05ef93 Link encap:Ethernet  HWaddr ca:ea:97:ef:cd:9d  
          inet6 addr: fe80::c8ea:97ff:feef:cd9d/64 Scope:Link
          .....

我相信我必须将 NetEm 规则应用于这些接口(interface)之一。这是正确的吗?

最佳答案

veth 路线似乎不太简单,但我认为基于 this answer 可能是可行的.

但是,默认情况下(使用桥接接口(interface))来自和发往容器 virt 接口(interface)的请求将通过默认桥接网络接口(interface) docker0

您可以在那里设置 NetEm 规则,但它也会减慢所有其他容器的速度。如果可以选择,那么在单独的网络上运行容器(使用 docker network create 创建)将是进行实验/测试的更简洁的方法。

docker network create slownet 
docker network inspect slownet
[
    {
        "Name": "slownet",
        "Id": "535e40d880716a27efe1fd3fada62bdc4d9fa13bde09279de650fa53f13f7cdd",
        "Scope": "local",
        "Driver": "bridge",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": {},
            "Config": [
                {
                    "Subnet": "172.19.0.0/16",
                    "Gateway": "172.19.0.1/16"
                }
            ]
        },
        "Internal": false,
        "Containers": {},
        "Options": {},
        "Labels": {}
    }
]
ifconfig
 .... 
br-535e40d88071 Link encap:Ethernet  HWaddr 02:42:4E:B6:F8:C2  
          inet addr:172.19.0.1  Bcast:0.0.0.0  Mask:255.255.0.0
          inet6 addr: fe80::42:4eff:feb6:f8c2%32727/64 Scope:Link
          UP BROADCAST MULTICAST  MTU:1500  Metric:1
          RX packets:180 errors:0 dropped:0 overruns:0 frame:0
          TX packets:180 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:14368 (14.0 KiB)  TX bytes:16888 (16.4 KiB)
.... 

# so br-535e40d88071 is the interface 

让我们启动容器并开始 ping:

host> docker run -ti --rm --net=slownet alpine sh    
container> ping 8.8.8.8 
PING 8.8.8.8 (8.8.8.8): 56 data bytes
64 bytes from 8.8.8.8: seq=114 ttl=37 time=0.251 ms

然后添加 NetEm 规则:

host> tc qdisc add dev br-535e40d88071 root netem delay 100ms

当这种情况发生时,我会看到延迟增加:

64 bytes from 8.8.8.8: seq=115 ttl=37 time=0.693 ms
64 bytes from 8.8.8.8: seq=116 ttl=37 time=101.086 ms
64 bytes from 8.8.8.8: seq=117 ttl=37 time=104.056 ms

关于networking - 在 Docker 容器接口(interface)上应用 NetEM WAN 延迟,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41899906/

相关文章:

docker - 此处不允许yml docker-compose错误映射值

wordpress - 错误 : Get https://registry-1. docker.io/v2/: net/http: 请求在等待连接时被取消-Docker 与 Wordpress

go - 什么字段对应于 netlink 中的 "dev"(设备)参数?

c - 使用 sk_buff 从内核中的 char* buf 发送数据包到网络设备

c# - 如何使用.NET监控应用程序状态?

c# - 异步 C# 服务器连续从多个套接字读取

ubuntu 上使用空间时 Dockerfile 出错

linux-kernel - 不同 ebpf 程序类型之间的映射共享

Android:SSDP 卡在 MulticastSocket.receive() 上