KVM Pass-through 上部署 MiniSMB HurricaneII
KVM Pass-through 上部署 MiniSMB HurricaneII
免费网络测试,是一款专门用于测试无线控制器, 智能路由器,网络交换机的性能和稳定性的软硬件相结合的工具。可以通过此工具在以太网上测试网络发包、网络压力测试任何ip网络设备的端口吞吐率,带宽等网络性能测试,并发连接数和最大连接数等诸多参数指标。
与软件Iperf,netperf, dpdk trafficgen相比较,MiniSMB属于专业硬件网络发包测试仪, 具备精准测试速率,高吞吐率,可模拟千万级连接数等特点。
本文主要介绍MiniSMB HurricaneII如何部署在KVM Pass-through
KVM 介绍
KVM 是 Kernel-based Virtual Machine 的简称,是一个开源的系统虚拟化模块,自 Linux
2.6.20 之后集成在 Linux 的各个主要发行版本中。它使用 Linux 自身的调度器进行管理。
KVM 目前已成为学术界的主流 VMM 之一。
KVM 的虚拟化需要硬件支持(如 Intel VT 技术或 AMD V 技术)。是基于硬件的完全虚拟
化。
所谓 Pass-through 技术是指可以将 PCI/PCIe 设备绕过虚拟机平台直接分配给虚拟机使用
下文是将 minismb HurricaneII 部署到 Pass-through 模式 KVM 的部署方法
宿主机:
CPU :Intel(R) Core(TM) i7-6800K CPU @ 3.40GHz 6核
系统: Fedora-Workstation-Live-x86_64-33-1.2
网卡:一对 Intel 82576 网卡
主要内容
- 安装 KVM 前准备
11.验证 cpu 是否支持 KVM
命令:cat /proc/cpuinfo | egrep 'vmx|svm'
效果:

一般情况下,出现关键词vmx表示支持;
12.在 BIOS 中开机虚拟化功能
方法:开启按 delete 键进入 BIOS 中--用键盘方向键选中“Advanced”菜单--选中“Intel Virtual Technology”—切换“Enabled”开启
(因每台机器BIOS界面差异,开启虚拟化功能的具体位置会不同)

13.关闭 SELinux
命令:vi /etc/sysconfig/selinux
效果:
将SELINUX=disabled 即可, 然后务必重启机器

- 安装 KVM
2.1 安装 KVM 包
命令:sudo dnf -y install bridge-utils libvirt virt-install qemu-kvm
2.2 安装 KVM 虚拟机工具
命令:sudo dnf -y install virt-top libguestfs-tools
命令:sudo dnf -y install virt-manager
说明:
libvirt:必须要装的核心工具
bridge-utils:虚拟机与外界通信的命令管理工具
virt-install:虚拟机安装工具
virt-manager:虚拟机图形管理工具(宿主机有桌面环境时可以考虑安装,命令操作或者远
程控制则不需要)
2.3 重启宿主机,加载 KVM 相关模块
命令:reboot
2.4 查看 KVM 模块是否被正确加载
命令:lsmod | grep kvm
出现以下信息则表示正确加载。

2.5 开启 KVM 服务,并设置开机启动
命令:systemctl start libvirtd.service(开启)
命令:systemctl enable libvirtd.service(开机启动)
第 7 页第 8 页
2.6 查看操作结果,出现 Active:active(running)字样则说明运行情况良好
命令:systemctl status libvirtd(启动状态)
命令:systemctl is-enabled libvirtd(是否开机自动启动)
效果:


- 网桥搭建
运行以下脚本创建网桥Br0, 注意 “BR_INTERFACE=enp5s0”要修改成管理网口的接口名字.在本例中使用 enp5s0
# make up a bridge name, I like br0
export BR_NAME=br0
# this will vary depending on the mobo/eth card. see `ip addr` to find device name
export BR_INTERFACE=enp5s0
# Get our device UUID
BR_INT_OG_UUID=$(nmcli -g GENERAL.CON-UUID device show "${BR_INTERFACE}")
# Create bridge
nmcli connection add type bridge autoconnect yes con-name "${BR_NAME}" ifname "${BR_NAME}"
# Disable STP
nmcli connection modify "${BR_NAME}" bridge.stp no
# Add our interface to our bridge
nmcli connection add type bridge-slave autoconnect yes con-name ${BR_INTERFACE} ifname ${BR_INTERFACE} master ${BR_NAME}
# Turn off our old interface
nmcli con down "${BR_INTERFACE}"
# Turn on our new bridge
nmcli con up "${BR_NAME}"
# delete our old interface config
nmcli con delete "${BR_INT_OG_UUID}"
- 启用 PCI Pass-through
4.1 开启intel_iommu
编辑文件/etc/default/grub 添加 intel_iommu=on 参数
效果:

4.2 更新 GRUB
命令:grub2-mkconfig -o /etc/grub2.cfg
重启: reboot
5. PCI 网卡分离
5.1 查找PCI设备ID
命令:lspci -nn | grep -i ethernet
效果:

注:上图 06:00.0 中 06 是 PCI bus number;00 是 PCI device number;0 是 Function number
5.2 分离PCI 网卡
命令:virsh nodedev-detach pci_0000_06_00_0 virsh nodedev-detach pci_0000_06_00_1
效果:

6.配置 KVM
命令:virt-manager 打开虚拟系统管理器图形化界面

6.1 添加存储池
选中QEMU/KVM 在Edit下 打开 Connection Details




找到我们提前准备好的镜像文件 minismb-rel-v2.0.img 点击右上角open;


6.2 创建虚拟机







6.3 添加PassThrough网卡
把从宿主机上分离出来的 PCI 网卡添加到虚拟机上来



MiniSMB成功运行

KVM Pass-through 上部署 MiniSMB HurricaneII的更多相关文章
- 在 CentOS7 上部署 zookeeper 服务
在 CentOS7 上部署 zookeeper 服务 1 用 SecureCRT 或 XShell 等 Linux 客户端工具连接至 CentOS7 服务器: 2 进入到 /usr/local/too ...
- 在阿里云ECS CentOS7上部署基于MongoDB+Node.js的博客
前言:这是一篇教你如何在阿里云的ECS CentOS 7服务器上搭建一个个人博客的教程,教程比较基础,笔者尽可能比较详细的把每一步都罗列下来,包括所需软件的下载安装和域名的绑定,笔者在此之前对Linu ...
- OpenStack-Ocata版+CentOS7.6 云平台环境搭建 — 5.在控制节点上部署计算服务Nova
计算服务Nova使用OpenStack Compute来托管和管理云计算系统. OpenStack Compute是基础架构即服务(IaaS)系统的主要部分. 主要模块用Python实现.OpenSt ...
- Nginx + FastCGI + Django在windows上部署及nginx常用命令
一般应用都是部署在linux系统上,不会在windows上部署,emmm..所以有兴趣的就瞧瞧吧哈哈 nginx工作原理: nginx用于处理静态文件,动态部分经由fastcgi .scgi或uWSG ...
- 在CentOS上部署kubernetes1.9.0集群
原文链接: https://jimmysong.io/kubernetes-handbook/cloud-native/play-with-kubernetes.html (在CentOS上部署kub ...
- fedora上部署ASP.NET——(卡带式电脑跑.NET WEB服务器)
andrew,20130601,guilin 本文记录在树莓派(fedora)上部署ASP.NET MVC2 的过程. 本文共分为六部分,分别是前置条件,Apache的安装,Mysql的安装,安装mo ...
- CentOS 7 上部署Mono 4 和Jexus 5.6
概述 在这篇文章中我们将讨论如何在CentOS 7操作系统,安装 jexus. mono 和 配置 jexus,因此它将能够在这种环境中运行一个asp.net mvc 4 应用.这篇文章是描述如何在 ...
- deepsooncms在Ubuntu 14.04上部署教程
deepsooncms在Ubuntu 14.04上部署教程 一.安装mono1.在命令行运行sudo apt-key adv --keyserver keyserver.ubuntu.com --re ...
- 基于Kubernetes在AWS上部署Kafka时遇到的一些问题
作者:Jack47 转载请保留作者和原文出处 欢迎关注我的微信公众账号程序员杰克,两边的文章会同步,也可以添加我的RSS订阅源. 交代一下背景:我们的后台系统是一套使用Kafka消息队列的数据处理管线 ...
随机推荐
- Mybatis 一级缓存和二级缓存的使用
目录 Mybatis缓存 一级缓存 二级缓存 缓存原理 Mybatis缓存 官方文档:https://mybatis.org/mybatis-3/zh/sqlmap-xml.html#cache My ...
- 【IMP】IMP导入表的时候,如果表存在怎么办
在imp导入的时候,如果表存在的话,会追加数据在表中, 所以如果不想追加在表中的话,需要将想导入的表truncate掉后,在imp SQL: truncate table TEST1; imp tes ...
- CTFHub - Web(六)
命令注入: 1.进入页面,测试127.0.0.1, 关键代码: <?php $res = FALSE; if (isset($_GET['ip']) && $_GET['ip'] ...
- os.walk() 遍历目录下的文件夹和文件
os.walk(top, topdown=True, onerror=None, followlinks=False) top:顶级目录 os.walk()返回一个三元tupple(dirpath, ...
- 国人之光:大数据分析神器Apache Kylin
一.简介 Apache Kylin是一个开源的.分布式的分析型数据仓库,提供Hadoop/Spark 之上的 SQL 查询接口及多维分析(OLAP)能力以支持超大规模数据,最初由 eBay 开发并贡献 ...
- 本地jar添加到本地仓库 本地jar依赖无效问题
最近工作发生了一个很奇怪的事情,我在本地写了一个项目,打包成jar,然后敲命令mvn install:install-file -DgroupId=com.yzwine -DartifactId=yz ...
- 《进击吧!Blazor!》第一章 1.初识 Blazor
作者介绍 陈超超 Ant Design Blazor 项目贡献者 拥有十多年从业经验,长期基于.Net技术栈进行架构与开发产品的工作,Ant Design Blazor 项目贡献者,现就职于正泰集团 ...
- Centos 7 网卡配置
网卡配置位置 1 /etc/sysconfig/network-scripts/ifcfg-ethx -----其中x为网卡名称,centos 默认网卡名称为ens33 如何配置 1 2 3 4 ...
- 【原创】Linux虚拟化KVM-Qemu分析(八)之virtio初探
背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: KVM版本:5.9 ...
- 极光推送的设备唯一性标识 RegistrationID
极光推送的设备唯一性标识 RegistrationID 极光推送的设备唯一性标识 RegistrationID | 极光博客 https://blog.jiguang.cn/registrationi ...