zoukankan      html  css  js  c++  java
  • iperf3测量一个网络最大带宽

    iperf3使用方法简介

    iperf3是用来测量一个网络最大带宽的工具。它支持调节各种参数比如发送持续时间,发送/接收缓存,通信协议。每次测试,它都会报告网络带宽,丢包率和其他参数。

    iperf3下载路径

    https://iperf.fr/iperf-download.php

    安装

    软件名称:iperf3-3.1.3-1.fc24.x86_64.rpm

    在终端中输入命令:rpm -ivh iperf3-3.1.3-1.fc24.x86_64.rpm

    使用
    首先需要在服务端启动iperf3工具;启动方法
    iperf3 -s (启动后使用默认的端口5201如需使用其他端口则需要添加 -p 端口号)
    
    其次在客户端启动iperf3工具,连接服务端发送测试码流:
    Iperf3  -u  -c  serverIP  -b 200M -i 1 -t 60 -l 300
    以上参数表示  使用udp进行测试; -c 为客户端运行并要指定服务端的IP地址;-b 表示使用的测试带宽;-i 表示每次报告的间隔,
    单位为秒;-t 表示以时间为测试结束条件进行测试,默认为 10 秒; -l 用于设置包的大小 (UDP包大小设置为300字节,PPS数值接近研发估算的dMCU实际使用情况,即每100M流量对应40K PPS)。
    以上参数输入后回车,即可进行带宽测试。其测试结果显示如下:
    

    iperf参数

    iPerf 工作模式和参数
    iPerf 的工作时需要指定 Server 模式或 Client 模式,通过不同的参数来区别(-s 和-c)。iPerf3 所支持的功能也都通过设置不同的参数来实现。iPerf 的参数分为 3 类:通用参数,Server 端参数,Client 端参数。通用参数为 Server 端和 Client 端都可以使用的参数。以下是 iPerf 3.1.2 支持的所有参数:

    • -p, --port #,Server 端监听、Client 端连接的端口号;
    • -f, --format [kmgKMG],报告中所用的数据单位,Kbits, Mbits, KBytes, Mbytes;
    • -i, --interval #,每次报告的间隔,单位为秒;
    • -F, --file name,测试所用文件的文件名。如果使用在 Client 端,发送该文件用作测试;如果使用在 Server 端,则是将数据写入该文件,而不是丢弃;
    • -A, --affinity n/n,m,设置 CPU 亲和力;
    • -B, --bind ,绑定指定的网卡接口;
    • -V, --verbose,运行时输出更多细节;
    • -J, --json,运行时以 JSON 格式输出结果;
    • --logfile f,输出到文件;
    • -d, --debug,以 debug 模式输出结果;
    • -v, --version,显示版本信息并退出;
    • -h, --help,显示帮助信息并退出。
    • Server 端参数:
    • -s, --server,以 Server 模式运行;
    • -D, --daemon,在后台以守护进程运行;
    • -I, --pidfile file,指定 pid 文件;
    • -1, --one-off,只接受 1 次来自 Client 端的测试,然后退出。
    • Client 端参数
    • -c, --client ,以 Client 模式运行,并指定 Server 端的地址;
    • -u, --udp,以 UDP 协议进行测试;
    • -b, --bandwidth #[KMG][/#],限制测试带宽。UDP 默认为 1Mbit/秒,TCP 默认无限制;
    • -t, --time #,以时间为测试结束条件进行测试,默认为 10 秒;
    • -n, --bytes #[KMG],以数据传输大小为测试结束条件进行测试;
    • -k, --blockcount #[KMG],以传输数据包数量为测试结束条件进行测试;
    • -l, --len #[KMG],读写缓冲区的长度,TCP 默认为 128K,UDP 默认为 8K;
    • --cport ,指定 Client 端运行所使用的 TCP 或 UDP 端口,默认为临时端口;
    • -P, --parallel #,测试数据流并发数量;
    • -R, --reverse,反向模式运行(Server 端发送,Client 端接收);
    • -w, --window #[KMG],设置套接字缓冲区大小,TCP 模式下为窗口大小;
    • -C, --congestion ,设置 TCP 拥塞控制算法(仅支持 Linux 和 FreeBSD );
    • -M, --set-mss #,设置 TCP/SCTP 最大分段长度(MSS,MTU 减 40 字节);
    • -N, --no-delay,设置 TCP/SCTP no delay,屏蔽 Nagle 算法;
    • -4, --version4,仅使用 IPv4;
    • -6, --version6,仅使用 IPv6;
    • -S, --tos N,设置 IP 服务类型(TOS,Type Of Service);
    • -L, --flowlabel N,设置 IPv6 流标签(仅支持 Linux);
    • -Z, --zerocopy,使用 “zero copy”(零拷贝)方法发送数据;
    • -O, --omit N,忽略前 n 秒的测试;
    • -T, --title str,设置每行测试结果的前缀;
    • --get-server-output,从 Server 端获取测试结果;
    • --udp-counters-64bit,在 UDP 测试包中使用 64 位计数器(防止计数器溢出)。
  • 相关阅读:
    JAVA 解压压缩包中指定文件或实现压缩文件的预览及下载单个或多个指定的文件
    java 解压zip java.lang.IllegalArgumentException: MALFORMED 错误
    Java文件管理系统
    Java实现用汉明距离进行图片相似度检测的
    url 编码(percentcode 百分号编码)
    nodejs进程管理
    nodejs网络编程
    nodejs内存溢出 FATAL ERROR: CALL_AND_RETRY_0 Allocation failed – process out of memory
    connect ECONNREFUSED 127.0.0.1:80错误解决
    nuxtjs如何在单独的js文件中引入store和router
  • 原文地址:https://www.cnblogs.com/pengsn/p/12954615.html
Copyright © 2011-2022 走看看