• 关于Azure带宽的测试


    以前见客户经常会碰到一些客户问我们你们Azure的带宽是多少,每次回答这个问题我们只能含糊地告诉客户一个大概数值,这样就会留给客户一个认为我们很不专业的印象,其实站在客户的角度我们也能理解,连这样的一个问题你都不能准确回答,我怎么能相信你能帮我运维,所以我与我同事抽空实测了一下,在这里我重点阐述如何进行测试,而不是对测试结果进行分析!!!

    测试条件,Azure中国区域的账号

    在测试之前,我想和读者稍微讲解一下本次的测试环境以及本次测试所用到的工具,本次的测试工具为iperf,具体版本为iperf3.1.3

    第一步,登陆账号,创建虚拟机,有两种创建方式,第一种是通过portal创建,另一种是通过powershell创建,创建虚拟机的步骤这里就不再演示,如果有不会的读者可以翻看我前面的博文进行参考,在本次poc环境里,我们以一台东部区域的D4虚拟机作为server端,4台北部A1作为client端,OS都为centos7.2,架构图如下;

    在这里笔者要说一下,之所以要将server端和client端放在不同的地域,是因为如果server端和client端都在同一个区域的话,两端的流量传输是不能出数据中心的,因为数据中心的边缘网关收到数据包,会拆包查看destination IP,如果发现该IP地址就在该数据中心内,边缘网关会直接将数据包丢给该IP地址的虚拟机,所以数据包不能出数据中心,其实大多数的网络带宽的瓶颈都在公网上,而不是内网,所以笔者的建议是如果有条件最好用本地服务器与Azure数据中心上的虚拟机做测试,由于笔者缺少本地服务器,也比较懒得去搭建环境,这里就在北部建了四台虚拟机作为client,数据包直接在连接两个数据中心的裸光纤进行传输,即便如此,iperf也不能将宽带吃满,所以并不能测出准确的结果,如果想测吃满裸光纤可以用Azcopy来进行测试,所以这里更偏向于方法论的展示,实际意义不大。 

    按照架构图建立好虚拟网络与虚拟机,结果如下

    接下来的工作就是安装iperf,我们首先通过SSH远程登陆到所有虚拟机,在安装iperf之前需要确保虚拟机OS都已经安装好make和gcc,由于Azure所提过的OS都是base版,所以大多数都需要我们自己安装

    在于server端,我们通过SSH登陆以后

    输入sudo yum install gcc  看到如下结果

    此时server端的gcc就安装成功了,接下来安装make

    输入sudo yum install make,结果如下

    表明make已经存在了,不必再去安装

    client端的操作也是一样,这里就不再一一展示

    接下来的工作就是下载并解压iperf源码包

    在server端,输入如下命令

    $sudo cd /tmp
    $sudo wget http://downloads.es.net/pub/iperf/iperf-3-current.tar.gz
    $sudo tar zxvf iperf-3-current.tar.gz

    完成以上步骤会在/tmp目录下看到如下结果

    接下来安装iperf

    $sudo cd iperf-3.1.4/
    $sudo ./configure
    $sudo make
    $sudo make install

    安装成功后,iperf被安装在/usr/local/bin目录下,进入该目录可以看到如下结果

    如果iperf运行报以下错误

    iperf3: error while loading shared libraries: libiperf.so.0: cannot open shared object file: No such file or directory

    输入Idconfig即可解决

    client端的安装方法同server端,这里就不再详细介绍

    这样,所有的虚拟机的iperf都安装好了,有人不禁会问,这样就好了嘛,当然不是,还有非常重要的一步,就是修改访问规则,因为两端有防火墙规则,必须修改完以后才能使用iperf进行测试,测试的时候我们要指定iperf server端监听的端口,这里设定为TCP-5001,在防火墙上就要开启TCP-5001端口相应的访问规则,在ASM中,我们需要配置终结点,在ARM中,需要配置NSG,由于本次poc环境都是在ARM中部署的,所以我们需要修改NSG,其实笔者的建议是最好都使用ARM,毕竟ARM多了很多功能,有些功能甚至已经不需要在powershell上完成,直接可以在ARM中完成。

    具体修改规则如下

    在server端的NSG添加如下规则

    接下来就可以开始测试了,首先我们在server端输入如下命令来监听5001端口,每两秒输出一次结果;

    $iperf3 -s -p 5001 -i 2 

    看到如下结果,表示iperf运行正常

    接下来就等待client端开始测试了,在client端输入如下命令

    $iperf3 -c 139.219.229.18 -P 4 -t 30 -i 2 -p 5001

    这条命令的意思就是client端并发4个数据流,测试时间为30s,每2s输出一次结果 

    首先我们看client vm1,截图如下

    serverD4端截图结果如下

    通过以上截图,我们可以看到带宽在120Mb左右,在这里笔者要提醒一下,四个client端只能轮流测试,也就是说当client vm1在测试时,其它client端是不能进行测试的,即使输入命令也不能正常进行测试,因为server端口处于busy状态,会出现如下截图

    在这里,其它client端的截图就不再展示,因为测试下来的带宽相对保持稳定,所以就不再展示截图,最后想提醒大家一下,因为该测试会产生流量的费用,所以在测试之前需要做好准备

  • 相关阅读:
    Java内存模型之从JMM角度分析DCL
    MySQL系列(九)--InnoDB索引原理
    MySQL系列(一)--基础知识(转载)
    MySQL系列(八)--数据库分库分表
    MySQL系列(七)--SQL优化的步骤
    MySQL系列(六)--索引优化
    MySQL系列(五)--二进制日志对主从复制的影响
    Java集合(七)--基于jdk1.8的HashMap源码
    Java数据结构和算法(八)--红黑树与2-3树
    Java数据结构和算法(七)--AVL树
  • 原文地址:https://www.cnblogs.com/chenjie520/p/6114622.html
Copyright © 2020-2023  润新知