我有一个 golang 程序,它通过 https 将大量数据上传到 OpenStack 对象存储。它依赖 golang 标准库"net/http"
来完成这项工作。我想用trickle
速率限制数据的上传,但使用涓流运行我的代码似乎没有任何效果(好像我根本没有使用涓流)。
为什么会这样?涓流或 golang 是否有一些限制阻止它们一起工作?有没有我没有考虑过的问题?
这是我的设置:
我知道trickle
这只适用于动态链接的可执行文件(请参阅涓流文档的第一段),所以我编译了我的代码,go build -compiler gccgo mycode.go
输出ldd myexecutable
为:
linux-vdso.so.1 => (0x00007ffee27b8000)
libgo.so.9 => /usr/lib/x86_64-linux-gnu/libgo.so.9 (0x00007f46062bf000)
libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f46060a9000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f4605cdf000)
/lib64/ld-linux-x86-64.so.2 (0x000055aa4d0a4000)
libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f4605ac2000)
libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f46057b9000)
我在 Ubuntu Linux 16.04 上运行它。我slurm
用来查看我的命令运行时的网络流量。这台机器没有运行任何其他网络密集型作业,所以我确信我看到了我的代码生成的流量。
当我跑
trickle -s -v -u2500 myexecutable ...args
我看到我的 TX 网络流量飙升至大约 12000KB/s(网络可以处理的最大值),而不是遵守我的 2500KB/s 限制。
谁能想到为什么会发生这种情况或我可以尝试解决什么?