tnblog
首页
视频
资源
登录

使用iPerf比较不同Docker网络设置的性能

7998人阅读 2021/6/22 11:15 总访问:3661117 评论:0 收藏:1 手机
分类: docker

Docker远征

使用iPerf比较不同Docker网络设置的性能

IPerf的介绍

iperf是一种命令行工具,用于通过测量服务器可以处理的最大网络吞吐量来诊断网络速度问题。它在遇到网络速度问题时特别有用,通过该工具可以确定哪个服务器无法达到最大吞吐量。
更多详细基本请参考:https://www.jianshu.com/p/15f888309c72

下载IPerf

  1. curl -LO https://iperf.fr/download/archlinux/iperf-2.0.5-9-x86_64.pkg.tar.xz
  2. # Pacman 是一个软件包管理器 -U 表示安装本地包
  3. yes | pacman -U iperf-2.0.5-9-x86_64.pkg.tar.xz

测试:主机连接主机

这复制了运行在同一主机上的两个进程,通过 TCP 相互连接。

  • nohup : 不挂断的运行,注意并没有后台运行的功能,,就是指,用nohup运行命令可以使命令永久的执行下去,和用户终端没有关系,例如我们断开SSH连接都不会影响他的运行,注意了nohup没有后台运行的意思;&才是后台运行;
  • Jobs: 通过jobsjobs -l显示后台运行的任务,可以通过命令kill -9 <PID>杀死。
  1. # -s 表示服务器
  2. # -p 表示服务器端口
  3. nohup iperf -s -p 5002 >/dev/null 2>&1 &
  4. # -c 表示客户端要测试的服务器地址
  5. iperf -c localhost -p 5002

10秒,传输39.5 G的数据,带宽为:33.9 Gbits/sec

测试:主机的客户端连接 Docker 的服务器

这复制了主机上的一个进程和一个容器内的一个进程,它们通过 TCP 相互连接。

  1. docker run -d -p 5001:5001 --name mapped-iperf benhall/iperf iperf -s
  2. iperf -c localhost

10秒,传输7.09 G的数据,带宽为:6.09 Gbits/sec,性能不如主机连主机。

测试: Docker 的进程通过链接进行通信

创建两个容器之间的链接,以便它们通过友好名称进行通信。

  1. docker run -d --name link-server benhall/iperf iperf -s
  2. docker run -it --link link-server:server benhall/iperf iperf -c server

10秒,传输31.7 G的数据,带宽为:27.2 Gbits/sec,性能良好。

测试: Docker 的进程通过网络进行通信

这使用 Docker 网络来创建桥。容器通过该桥进行通信。

  1. # 创建iperf网络
  2. docker network create iperf
  3. # 服务器
  4. docker run -d --net=iperf --name network-server benhall/iperf iperf -s
  5. # 客户端
  6. docker run -it --net=iperf benhall/iperf iperf -c network-server

10秒,传输30.6 G的数据,带宽为:26.3 Gbits/sec,性能良好。

测试: Docker 的进程通过共享网络命名空间进行通信(container)

使用共享网络的容器。

  1. docker run -d --name shared-server benhall/iperf iperf -s
  2. docker run -it --net=container:shared-server benhall/iperf iperf -c localhost

10秒,传输47.8 G的数据,带宽为:47.8 Gbits/sec,性能超高。

测试:使用主机网络的进程

容器客户端,通过主机网络连接到主机

  1. docker run -it --net=host benhall/iperf iperf -c 172.19.0.1 -p 5002

10秒,传输37.9 G的数据,带宽为:32.6 Gbits/sec,性能比较高。

容器服务器,通过主机网络连接到主机上的客户端

  1. docker rm -f mapped-iperf
  2. docker run -d --net=host benhall/iperf iperf -s
  3. iperf -c localhost

10秒,传输40.5 G的数据,带宽为:34.8 Gbits/sec,性能比较高。


欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739

评价
这一世以无限游戏为使命!
排名
7
文章
192
粉丝
15
评论
16
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术