文档章节

KVM网络性能测试(2)

anglix
 anglix
发布于 2015/12/28 00:54
字数 862
阅读 572
收藏 6

测试结论

  • kvm使用virtio虚拟网卡,网络小包处理能力损失了3/4。

测试过程

测试场景

  • 本文接 KVM网络性能测试(1)
  • 同样是16台服务器:同样是15台用作压测客户端,同样1台被测试。
  • 同样是用工具 Ngrinder ,同样是测试 Tengine 的状态页面。
  • 不同的是,这次我们用的品牌机、万兆网卡,并发用户数加大了。
  • 用相同的测试方法:
  1. 测试物理机的网络性能(24C/32G)
tps = 227,115.4
mtt = 78.18
错误率 = 0.00% # 硬是不出错
虚拟用户 = 18000
  1. 分别测试1台虚拟机的网络性能(12C/8G、12C/8G)
tps = 49,650.8 、 49,724.9
mtt = 53.63 、 51.52
错误率 = 9.15% 、 9.19%
虚拟用 户= 18000 、18000
  1. 提高1台虚拟机的配置再测试(24C/8G、24C/8G)
tps = 37,318.6 、 37,380.5
mtt = 84.69 、 86.55
错误率 = 11.42% 、 11.33%
虚拟用户 = 18000 、18000
  1. 同时测试2台虚拟机的网络性能(12C/8G + 12C/8G)
tps = 53,280.6
mtt = 98.13
错误率 = 7.14%
虚拟用户 = 18000

此时宿主机资源并未完全耗尽:
宿主机资源使用
其上两台虚拟机的资源也未耗尽,但st%的占用表示有资源争抢:
虚拟机资源争抢

测试结果

  • 25万tps时:pps/in = 1,237 k , pps/out = 742 k
    测试结果
  • 宿主机 TPS超22万,虚拟机最高不到 6万。性能损失了3/4!
    网络封包数量
  • 测试结果令人震惊,于是不敢相信地又跑了一次物理机测试,然而结果重现、还硬不报错。

测试环境

  • 宿主机为戴尔M620,CPU=24核、内存=32G、硬盘=240G-ssd。
  • 压测机器为15台同配置物理机,CPU=4核、内存=32G、硬盘=240G-ssd。
# libvirtd --version
libvirtd (libvirt) 1.2.9
# nginx -v
Tengine version: Tengine/2.1.1 (nginx/1.6.2)
# kvm --version
QEMU emulator version 2.1.2 (Debian 1:2.1+dfsg-12+deb8u4), Copyright (c) 2003-2008 Fabrice Bellard
Intel(R) Xeon(R) CPU E5-2620 v2 @ 2.10GHz * 24
Jessie-8.2 3.16.0-4-amd64 #1 SMP Debian 3.16.7-ckt11-1+deb8u3 (2015-08-04) x86_64 
Ethernet controller: Broadcom Corporation NetXtreme II BCM57810 10 Gigabit Ethernet
  • 虚拟机的配置 virsh dumpxml kvm-net-perfmon:
<domain type='kvm' id='7'>
  <name>kvm-net-perfmon</name>
  <memory unit='KiB'>16777216</memory>
  <currentMemory unit='KiB'>8388608</currentMemory>
  <vcpu placement='static'>12</vcpu>
  <resource>
    <partition>/machine</partition>
  </resource>
  <os>
    <type arch='x86_64' machine='pc-i440fx-2.1'>hvm</type>
    <boot dev='hd'/>
  </os>
  <features>
    <acpi/>
  </features>
  <cpu mode='host-passthrough'>
    <topology sockets='1' cores='12' threads='1'/>
  </cpu>
  <clock offset='utc'/>
  <on_poweroff>destroy</on_poweroff>
  <on_reboot>restart</on_reboot>
  <on_crash>destroy</on_crash>
  <devices>
    <emulator>/usr/bin/kvm</emulator>
    <disk type='network' device='disk'>
      <driver name='qemu' type='raw'/>
      <auth username='higkoo'>
        <secret type='ceph' uuid='666a519f-afae-0d6f-2233-99c88888ceb3'/>
      </auth>
      <source protocol='rbd' name='libvirt-pool/1018-kvm-net-perfmon'>
        <host name='192.168.31.116' port='2233'/>
        <host name='192.168.31.101' port='2233'/>
        <host name='192.168.31.132' port='2233'/>
        <host name='192.168.31.118' port='2233'/>
        <host name='192.168.31.102' port='2233'/>
      </source>
      <backingStore/>
      <target dev='vda' bus='virtio'/>
      <iotune>
        <total_iops_sec>800</total_iops_sec>
      </iotune>
      <alias name='virtio-disk0'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/>
    </disk>
    <controller type='usb' index='0'>
      <alias name='usb0'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x2'/>
    </controller>
    <controller type='pci' index='0' model='pci-root'>
      <alias name='pci.0'/>
    </controller>
    <interface type='bridge'>
      <mac address='11:22:33:00:c6:a8'/>
      <source bridge='br100'/>
      <target dev='vnet1'/>
      <model type='virtio'/>
      <alias name='net0'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x05' function='0x0'/>
    </interface>
    <serial type='pty'>
      <source path='/dev/pts/1'/>
      <target port='0'/>
      <alias name='serial0'/>
    </serial>
    <console type='pty' tty='/dev/pts/1'>
      <source path='/dev/pts/1'/>
      <target type='serial' port='0'/>
      <alias name='serial0'/>
    </console>
    <input type='tablet' bus='usb'>
      <alias name='input0'/>
    </input>
    <input type='mouse' bus='ps2'/>
    <input type='keyboard' bus='ps2'/>
    <graphics type='vnc' port='2333' autoport='yes' listen='0.0.0.0'>
      <listen type='address' address='0.0.0.0'/>
    </graphics>
    <video>
      <model type='cirrus' vram='9216' heads='1'/>
      <alias name='video0'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x02' function='0x0'/>
    </video>
    <memballoon model='virtio'>
      <alias name='balloon0'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x04' function='0x0'/>
    </memballoon>
  </devices>
</domain>

© 著作权归作者所有

anglix

anglix

粉丝 32
博文 35
码字总数 17615
作品 0
珠海
系统管理员
私信 提问
KVM网络性能测试(1)

测试结论 kvm使用virtio虚拟网卡,网络小包处理能力损失近半。 测试过程 测试场景 共16台服务器:其中15台用作压测客户端,1台被测试。 测试工具使用 Ngrinder ,测试 Tengine 的状态页面。 ...

anglix
2015/12/27
747
2
kvm虚拟机 nginx性能测试

暂时停止对mongodb的性能测试 因为前端做负载均衡的nginx性能提升不上去 由于经费 还有目前测试条件的限制 我们做的性能测试都是在KVM虚拟机里搭建的环境 nginx1.2.6 测试工具就是apache be...

pengfei_xue
2013/02/03
4.7K
19
如果使用Docker后,还需要OpenStack吗?

Solomon Hykes创立了Docker,没有想到过Docker会人气爆棚,成为仅次于OpenStack的最受欢迎的云开源项目。 然而听说过Docker的朋友很少知道其真正的意义,很多人会被各种概念混淆,甚至把Ope...

架构师技术联盟
2018/09/19
0
0
KVM网络性能测试(3)

测试结论 开启虚拟机的VCPU绑定后,网络小包处理性能上升约 、相对物理机性能损耗约 。 测试过程 测试宿主机的小包处理性能,以Tengine的状态页面为例 测试默认情况下kvm虚拟机的小包处理性能...

anglix
2016/01/05
264
0
阿里云异构计算团队亮相英伟达2018 GTC大会

1、首届云原生计算国际会议上,弹性计算研究员伯瑜介绍了基于虚拟化、容器化编排技术的云计算操作系统PouchContainer 首届云原生计算国际会议(KubeCon + CloudNativeCon,China,2018)在上...

迷你芊宝宝
2018/12/04
12
0

没有更多内容

加载失败,请刷新页面

加载更多

你知道多少this,new,bind,call,apply?那我告诉你

那么什么是this,new,bind,call,apply呢?这些你都用过吗?掌握这些内容都是基础中的基础了。如果你不了解,那还不赶快去复习复习,上网查阅资料啥的! 通过call,apply,bind可以改变thi...

达达前端小酒馆
今天
5
0
设计模式之命令模式

命令模式的类图 其中的角色有: Client 客户端。只依赖于调用者Invoker、接收者Receiver、以及Command(网上找的图片这里没有画出来),不用关注接收者如何执行命令,只需要告诉调用者需要执行...

陈年之后是青葱
今天
7
0
2. 彤哥说netty系列之IO的五种模型

你好,我是彤哥,本篇是netty系列的第二篇。 欢迎来我的公从号彤哥读源码系统地学习源码&架构的知识。 简介 本文将介绍linux中的五种IO模型,同时也会介绍阻塞/非阻塞与同步/异步的区别。 何...

彤哥读源码
今天
5
0
OSChina 周四乱弹 —— 喵的波粒二象性

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @ 小小编辑推荐:《水墨兰亭》- 李志辉 《水墨兰亭》- 李志辉 手机党少年们想听歌,请使劲儿戳(这里) @巴拉迪维 :卧室里采光要足够好,这样...

小小编辑
今天
45
2
前后端分离接口规范

最近在开发,遇到前后端关于Boolean类型的参数传参和接收的问题: 场景:后台会根据用户是否出车/是否出司机(Boolean类型)来决定后端的业务逻辑(比如费用的计算),前端使用JSON字符串类型...

code-ortaerc
昨天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部