位置: 编程技术 - 正文

KVM虚拟网络优化方案整理(kvm虚拟化网络配置)

编辑:rootadmin

推荐整理分享KVM虚拟网络优化方案整理(kvm虚拟化网络配置),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:kvm虚拟化性能,kvm虚拟化网络配置,kvm虚拟化网络配置,kvm虚拟化技术,kvm 虚拟网卡,kvm虚拟化性能,kvm 虚拟网卡,kvm虚拟化性能,内容如对您有帮助,希望把文章链接给更多的朋友!

一个完整的数据包从虚拟机到物理机的路径是:

虚拟机--QEMU虚拟网卡--虚拟化层--内核网桥--物理网卡

KVM的网络优化方案,总的来说,就是让虚拟机访问物理网卡的层数更少,直至对物理网卡的单独占领,和物理机一样的使用物理网卡,达到和物理机一样的网络性能。

方案一 全虚拟化网卡和virtio

Virtio与全虚拟化网卡区别 全虚拟化网卡是虚拟化层完全模拟出来的网卡,半虚拟化网卡通过驱动对操作系统做了改造; viritio简单的说,就是告诉虚拟机,hi 你就是在一个虚拟化平台上跑,咱们一起做一些改动,让你在虚拟化平台上获得更好的性能;

关于virtio的使用场景 因 为windows虚拟机使用viritio有网络闪断的情况发生,windows 虚拟机如果网络压力不高,建议使用e这样的全虚拟化网卡,如果网络压力比较高,建议使用SRIVO或者PCI Device Assignment这样的技术;viritio也在不断的演进,希望windows的闪断的问题越来越少。

KVM天生就是为linux系统设计的,linux系统请放心大胆的使用viritio驱动;

方案二 vhost_net macvtap技术

vhost_net使虚拟机的网络通讯直接绕过用户空间的虚拟化层,直接可以和内核通讯,从而提供虚拟机的网络性能;

macvtap则是跳过内核的网桥;

使用vhost_net,必须使用virtio半虚拟化网卡;

vhost_net虚拟机xml文件配置,

XML/HTML Code复制内容到剪贴板 <interface type='bridge'> <mac address=''/> <source bridge='br0'/> <model type='virtio'/> <driver name="vhost"/> <address type='pci' domain='0x' bus='0x' slot='0x' function='0x0'/> </interface>

如果不使用vhost_net,则为 <driver name="qemu"/>

macvtap 虚拟机xml配置

XML/HTML Code复制内容到剪贴板 <interface type='direct'> <mac address='::3e:d5:d6:'/> <source dev='lo' mode='bridge'/> <model type='e'/> <address type='pci' domain='0x' bus='0x' slot='0x' function='0x0'/> </interface>

注意:macvtap在windows虚拟机上性能很差,不建议使用

vhost_net macvtap比较

macvlan的功能是给同一个物理网卡配置多个MAC地址,这样可以在软件商配置多个以太网口,属于物理层的功能。 macvtap是用来替代TUN/TAP和Bridge内核模块,macvtap是基于macvlan这个模块,提供TUN/TAP中tap设备使用的接口, 使用macvtap以太网口的虚拟机能够通过tap设备接口,直接将数据传递到内核中对应的macvtap以太网口。 vhost-net是对于virtio的优化,virtio本来是设计用于进行客户系统的前端与VMM的后端通信,减少硬件虚拟化方式下根模式个非根模式的切换。 而是用vhost-net后,可以进一步进入CPU的根模式后,需要进入用户态将数据发送到tap设备后再次切入内核态的开销,而是进入内核态后不需要在进行内核态用户态的切换,进一步减少这种特权级的切换,说vhost-net属于哪个层不准确,而是属于进行二层网络数据传递的优化。

KVM虚拟网络优化方案整理(kvm虚拟化网络配置)

方案三 虚拟机网卡独占

网卡passthrough在虚拟机的配置方法

1 使用lcpci 设备查看pci设备信息 复制代码代码如下::.0 Ethernet controller: Intel Corporation EB Gigabit Ethernet Controller (rev ):.1 Ethernet controller: Intel Corporation EB Gigabit Ethernet Controller (rev )

也可以使用virsh nodedev-list –tree得到信息 复制代码代码如下:+- pci____0| || +- pci____0| | || | +- net_p1p1__1b____dc| | | +- pci____1| || +- net_p1p2__1b____dd

2 使用virsh nodedev-dumxml pci____0得到xml配置信息 复制代码代码如下:[root@]# virsh nodedev-dumpxml pci____0 <device><name>pci____0</name><parent>pci____0</parent><driver> <name>ee</name></driver><capability type='pci'> <domain>0</domain> <bus>4</bus> <slot>0</slot> <function>0</function> <product id='0xe'>EB Gigabit Ethernet Controller</product> <vendor id='0x'>Intel Corporation</vendor></capability></device>

3 编辑虚拟机xml文件,加入pci设备信息 复制代码代码如下:<hostdev mode='subsystem' type='pci' managed='yes'> <source> <address domain='0x' bus='0x' slot='0x' function='0x0'/> </source></hostdev>

Domain bus slot function信息从dumpxml出的xml文件获取,define虚拟机,然后开启虚拟机就可以,注意以为附件上去的是物理设备,需要在系统里面安装相应的驱动。

方案四 SR-IVO技术

SRIOV的原理 SR-IVO 是the single root I/O virtualization 的简写,是一个将PCIe共享给虚拟机使用的标准,目前用在网络设备上比较多,理论上也可以支持其他的PCI设备,SRIOV需要硬件的支持。

以下内容来自oracle网站,链接为 (Physical Function, PF) 用 于支持 SR-IOV 功能的 PCI 功能,如 SR-IOV 规范中定义。PF 包含 SR-IOV 功能结构,用于管理 SR-IOV 功能。PF 是全功能的 PCIe 功能,可以像其他任何 PCIe 设备一样进行发现、管理和处理。PF 拥有完全配置资源,可以用于配置或控制 PCIe 设备。 虚拟功能 (Virtual Function, VF) 与物理功能关联的一种功能。VF 是一种轻量级 PCIe 功能,可以与物理功能以及与同一物理功能关联的其他 VF 共享一个或多个物理资源。VF 仅允许拥有用于其自身行为的配置资源。 每 个 SR-IOV 设备都可有一个物理功能 (Physical Function, PF),并且每个 PF 最多可有 , 个与其关联的虚拟功能 (Virtual Function, VF)。PF 可以通过寄存器创建 VF,这些寄存器设计有专用于此目的的属性。 一 旦在 PF 中启用了 SR-IOV,就可以通过 PF 的总线、设备和功能编号(路由 ID)访问各个 VF 的 PCI 配置空间。每个 VF 都具有一个 PCI 内存空间,用于映射其寄存器集。VF 设备驱动程序对寄存器集进行操作以启用其功能,并且显示为实际存在的 PCI 设备。创建 VF 后,可以直接将其指定给 IO 来宾域或各个应用程序(如裸机平台上的 Oracle Solaris Zones)。此功能使得虚拟功能可以共享物理设备,并在没有 CPU 和虚拟机管理程序软件开销的情况下执行 I/O。 SR-IOV 的优点 SR-IOV 标准允许在 IO 来宾域之间高效共享 PCIe 设备。SR-IOV 设备可以具有数百个与某个物理功能 (Physical Function, PF) 关联的虚拟功能 (Virtual Function, VF)。VF 的创建可由 PF 通过设计用来开启 SR-IOV 功能的寄存器以动态方式进行控制。缺省情况下,SR-IOV 功能处于禁用状态,PF 充当传统 PCIe 设备。 具有 SR-IOV 功能的设备可以利用以下优点: 性能-从虚拟机环境直接访问硬件。 成本降低-节省的资本和运营开销包括: 节能 减少了适配器数量 简化了布线 减少了交换机端口 SRIOV的使用 启动SRIVO内核模块 modprobe igb 激活虚拟功能VF modprobe igb max_vfs=7 千兆网卡最多支持8个vf0-7,千兆网卡目前支持比较好的是INTEL I, S虽然也支持SRIOV但是只支持虚拟机是linux的情况,windows系统不支持; 万兆网卡最多支持个vg0-,intel的新新一代万兆网卡都支持SRIOV x x等; 如果需要重新设置vf 可以删除模块在重新加载 modprobe -r igb 将配置永久写入配置文件 echo "options igb max_vfs=7" >>/etc/modprobe.d/igb.conf 通过lspci命令可以看多主网卡和子网卡 复制代码代码如下:# lspci | grep 0b:.0 Ethernet controller: Intel Corporation Gigabit Network Connection (rev ) 0b:.1 Ethernet controller: Intel Corporation Gigabit Network Connection (rev ) 0b:.0 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.1 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.2 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.3 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.4 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.5 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.6 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.7 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.0 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.1 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.2 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.3 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.4 Ethernet controller: Intel Corporation Virtual Function (rev ) 0b:.5 Ethernet controller: Intel Corporation Virtual Function (rev )

虚拟机可以听过pci网卡独占的方式使用子网卡; 复制代码代码如下: # virsh nodedev-list | grep 0b pci__0b__0 pci__0b__1 pci__0b__0 pci__0b__1 pci__0b__2 pci__0b__3 pci__0b__4 pci__0b__5 pci__0b__6 pci__0b__7 pci__0b__1 pci__0b__2 pci__0b__3 pci__0b__4 pci__0b__5

虚拟机网卡xml文件

XML/HTML Code复制内容到剪贴板 <interface type='hostdev' managed='yes'> <source> <address type='pci' domain='0' bus='' slot='' function='0'/> </source> </interface>

方案五 网卡多队列

centos 7开始支持virtio网卡多队列,可以大大提高虚拟机网络性能,配置方法如下:

虚拟机的xml网卡配置

XML/HTML Code复制内容到剪贴板 <interface type='network'> <source network='default'/> <model type='virtio'/> <driver name='vhost' queues='N'/> </interface>

N 1 - 8 最多支持8个队列

在虚拟机上执行以下命令开启多队列网卡 复制代码代码如下: #ethtool -L eth0 combined M

M 1 - N M小于等于N

KVM网络优化方案个人认为以硬件为主,硬件上万兆+SRIOV的方案会越来越普及,但是在线迁移的问题有待解决。

在Linux系统中将SSD当块设备缓存的方法 原理写操作先缓存到ssd硬盘上,然后通过一定策略写到普通硬盘上;读操作热点数据可以缓存到ssd硬盘上,提高读取数据的速度。软件ssd缓存开源软件

为何数据中心要使用配置管理系统? 由于结合了额外的自动化功能,配置管理节约了IT团队的时间。那为什么有些数据中心对它视若不见呢?配置管理已经从服务器农场中的暗黑艺术解放出

vmware虚拟机怎么隐藏菜单工具栏? Vmware虚拟机软件可以用于模拟安装测试环境,??┓⑾?mware升级之后大概从6.0版本开始。菜单栏和工具栏等右击就没有隐藏的功能了,那么怎么才能隐藏菜

标签: kvm虚拟化网络配置

本文链接地址:https://www.jiuchutong.com/biancheng/354087.html 转载请保留说明!

上一篇:使用guestfish来管理KVM容器的详细教程(guest怎么用)

下一篇:在Linux系统中将SSD当块设备缓存的方法(在linux操作系统中)

  • 税控盘减免税款月末如何结转
  • 如何查询个人所有贷款记录
  • 发票专票抵扣
  • 代扣代缴增值税是什么意思
  • 保险政保业务
  • 全年没有超过起征点需要汇算吗
  • 发票作废了清单一样怎么重新使用
  • 公司购买的
  • 办公用品普通发票的会计分录
  • 经营许可证要交税吗
  • 个体户未抄报不能领发票
  • 增票普票税额是否可以抵扣吗
  • 一般纳税人工会经费返还政策
  • 初始数据试算表不平衡的原因
  • 企业所得税税前扣除政策
  • 印花税这个月没交怎么办
  • 退休返聘人员被辞退未提前通知能要求多付一个月工资吗
  • 工程完工进项税税务局不给退,走那个科目销毁
  • 报关单出口退税联在哪打印
  • 研发失败的项目可以加计扣除吗
  • 出口的增值税到底怎么算的
  • 自然人股息红利免征个人所得税?
  • 1697510586
  • 企业怎么通过债务转让
  • 华为mate手机sim卡怎么插
  • 收到退回的土地使用税分录怎么做
  • 收到投标保证金利息会计分录
  • 报销招待费的会计怎么做
  • nmeo.exe是什么
  • 进项发票没认证可以开红字申请单吗
  • 注册资金印花税税目
  • 收到发票已入账,退回怎么做账
  • 深度优先python
  • php网站结构
  • 阿尔卑斯旱獭冬眠
  • 史上最贵的微博
  • excel导出exe
  • 托收账款属于什么会计科目
  • 马萨诸塞 下架
  • node.js deno
  • wordpress jquery
  • 新会计准则规定
  • 非营利组织会计就是用于确认、计量
  • 个人所得税数据怎么导入新电脑
  • 税务已注销工商如何注销
  • 采购流程内容
  • 如何在税控盘上申领发票
  • 调整以前年度少计收入
  • 库存商品暂估入库是什么意思
  • 开个分公司有啥好处
  • 销售成品油的税率
  • 主办会计的工作内容和职责
  • 实收资本什么时候交齐
  • 职工教育经费产生的差异
  • 税局代开的专票能作废或红冲吗?
  • 网吧的收入怎么做账
  • 结转收入会计分录怎么做
  • 税控盘清卡时间
  • 修建的道路怎么做账
  • 应付账款怎么做平
  • mysql启动时报1067
  • sql server 服务器配置
  • 32位win7系统多大?
  • win10首个正式版发布日期
  • linux系统输入法锁定了怎么解开
  • wcesmgr.exe - wcesmgr 是什么进程
  • linux page buffer cache深入理解
  • Win7系统安装方法
  • windows8.1crazy error
  • perl -pe
  • cocos-2dx
  • 举例简介三国演义人物塑造的主要手法
  • itween常用方法
  • Python Requests 基础入门
  • JavaScript onkeydown事件入门实例(键盘某个按键被按下)
  • js弹出对话框的命令
  • javascript原生函数的源代码
  • 国家税务江苏税务总局官网
  • 办税服务厅限时办结制度
  • 税务工作者发展现状
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设