虚拟化逻辑架构:KVM虚拟机通过OVS端口组实现网络连接

目录

一、实验

1.CentOS 7 安装 OpenVSwitch(构建RPM安装包)

2.KVM虚拟机通过OVS端口组实现网络连接

二、问题

1.安装openvswitch-2.5.10报错

2.virt-install未找到命令

3.如何删除自定义网络


一、实验

1.CentOS 7 安装 OpenVSwitch(构建RPM安装包)

(1)关闭Selinux或设置为Permissive

①查看配置文件的命令 cat /etc/selinux/config 来查看状态

cat /etc/selinux/config 

发现SELinux共有3个状态enforcing (执行中)、permissive (不执行但产生警告)、disabled(关闭)。

②也可以用这个命令检查:getenforce

getenforce

③也可以用下述命令;如果SELinux status参数为enabled即为开启状态

/usr/sbin/sestatus -v

④临时关闭(重启机器后失效)

#setenforce 0设置为permissive模式;setenforce 1 设置为enforcing模式;
setenforce 0   

⑤永久关闭(需要重启机器)

#重启机器即可
sed -i s#SELINUX=enforcing#SELINUX=disabled# /etc/selinux/config

(2)安装依赖包

yum -y install wget openssl-devel gcc make python-devel openssl-devel kernel-devel graphviz kernel-debug-devel autoconf automake rpm-build redhat-rpm-config libtool python-twisted-core python-zope-interface PyQt4 desktop-file-utils libcap-ng-devel groff checkpolicy selinux-policy-devel

(3)下载OpenVSwitch软件包到本地

官网下载:

Download (openvswitch.org)

wget https://www.openvswitch.org/releases/openvswitch-2.5.10.tar.gz

(4)预处理

mkdir -p ~/rpmbuild/SOURCEScp openvswitch-2.5.10.tar.gz ~/rpmbuild/SOURCES/cd ~/rpmbuild/SOURCES
tar -zxvf openvswitch-2.5.10.tar.gz

(6)构建RPM包

cd ~/rpmbuild/SOURCES
rpmbuild -bb --nocheck openvswitch-2.5.10/rhel/openvswitch-fedora.spec

(7)安装

yum -y localinstall ~/rpmbuild/RPMS/x86_64/openvswitch-2.5.10-1.el7.centos.x86_64.rpm 

(8)查看OVS工具版本状态

ovs-vsctl -V

(9)手动创建目录

mkdir /var/run/openvswitch

(10)开启Open VSwitch服务并设置开机自启动

systemctl enable openvswitch
systemctl start openvswitch

(11)检查服务是否启动

systemctl is-active openvswitch

2.KVM虚拟机通过OVS端口组实现网络连接

(1)查看KVM存储磁盘文件

# cd  /var/lib/libvirt/images/
# ls

如果没有需要创建:

qemu-img create -f qcow2  /var/lib/libvirt/images/vm01.qcow2 10Gqemu-img create -f qcow2  /var/lib/libvirt/images/vm02.qcow2 10G

(2)查看KVM网络配置文件

# cd /etc/libvirt/qemu/networks/
# ls

(3)启动管理,查看当前虚拟机状况

# virt-manager

(4)强制关闭vm01,查看当前虚拟机状况

# virsh destroy vm01

(5)删除vm01,查看当前虚拟机状况

# virsh undefine vm01

(6)强制关闭vm02,查看当前虚拟机状况

# virsh destroy vm02

(7)删除vm02,查看当前虚拟机状况

# virsh undefine vm01

(8) 声明网络OVS端口组配置文件

echo "<network><name>ovs01_network</name><forward mode='bridge'/><bridge name='ovs01'/><virtualport type='openvswitch' /><portgroup name='default_vlan' default='yes'><vlan><tag id='0'/></vlan></portgroup><portgroup name='vlan10'><vlan><tag id='10'/></vlan></portgroup><portgroup name='vlan20'><vlan><tag id='20'/></vlan></portgroup></network>" >> /etc/libvirt/qemu/networks/ovs01_network.xml

(5)查看配置文件

(6) 定义并启动网络

# virsh net-define /etc/libvirt/qemu/networks/ovs01_network.xml# virsh net-start ovs01_network# virsh net-autostart ovs01_network

(7)列出当前虚拟化中定义的网络

# virsh net-list

(8)上传镜像:TinyCore-11.0.iso 

(9)创建

(9)创建OVS 虚拟交换机

# ovs-vsctl add-br ovs01
# ovs-vsctl show

(10)创建vm01

#创建VM01
virt-install \
--name=vm01 \
--cdrom=/var/lib/libvirt/images/TinyCore-11.0.iso \
--os-type=linux \
--os-variant=fedora18 \
--cpu host \
--vcpus 2,maxvcpus=4 \
--memory 512 \
--disk=/var/lib/libvirt/images/vm01.qcow2 \
--network network=ovs01_network,target=if01,mac=02:01:01:01:01:01

(11)查看OVS 虚拟交换机

# ovs-vsctl show

(12)创建vm02

#创建VM02
virt-install \
--name=vm02 \
--cdrom=/var/lib/libvirt/images/TinyCore-11.0.iso \
--os-type=linux \
--os-variant=fedora18 \
--cpu host \
--vcpus 2,maxvcpus=4 \
--memory 512 \
--disk=/var/lib/libvirt/images/vm02.qcow2 \
--network network=ovs01_network,target=if02,mac=02:01:01:01:01:02

(13)查看OVS 虚拟交换机

# ovs-vsctl show

(14)查看虚拟机vm01

# virsh edit vm01……<interface type='network'><mac address='02:01:01:01:01:01'/><source network='ovs01_network'/><target dev='if01'/><model type='virtio'/><address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/></interface>
……

(15) 查看虚拟机vm02

# virsh edit vm01……<interface type='network'><mac address='02:01:01:01:01:02'/><source network='ovs01_network'/><target dev='if02'/><model type='virtio'/><address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/></interface>
……

(16)手动给端口if01添加10网段并查看

# ovs-vsctl set port if01 tag=10
# ovs-vsctl show

(17) 修改vm02添加20段网络

# virsh edit vm02……<interface type='network'><mac address='02:01:01:01:01:02'/><source network='ovs01_network' portgroup='vlan20'/><target dev='if02'/><model type='virtio'/><address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/></interface>
……

(18)强制关机vm02并查看

# virsh destroy vm02# ovs-vsctl show

(19)启动虚拟机vm02并查看,网段20自动添加

# virsh start vm02# ovs-vsctl show

(20)强制关机vm01并查看

# virsh destroy vm01# ovs-vsctl show

(21)启动虚拟机vm01并查看,网段10没有自动添加,恢复为0网段,说明手动给端口添加网段在关机重启后会失效

# virsh start vm01# ovs-vsctl show

(22)修改vm01添加10段网络

# virsh edit vm01……<interface type='network'><mac address='02:01:01:01:01:01'/><source network='ovs01_network' portgroup='vlan10'/><target dev='if01'/><model type='virtio'/><address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/></interface>
……

(23)强制关机vm01并查看

# virsh destroy vm01# ovs-vsctl show

(24)启动虚拟机vm01并查看,网段10自动添加

# virsh start vm01# ovs-vsctl show

二、问题

1.安装openvswitch-2.5.10报错

(1)报错

In file included from lib/netlink-conntrack.c:26:0:
/usr/include/linux/netfilter/nf_conntrack_sctp.h:25:2: error: unknown type name 'u8'u8 last_dir;^
/usr/include/linux/netfilter/nf_conntrack_sctp.h:26:2: error: unknown type name 'u8'u8 flags;^

(2)原因分析

CentOS7内核升级到kernel-3.10.0-1160.2.2.el7.x86_64后,OVS2.5.10构建RPM安装包时可能会出错。
linux内核版本kernel-3.10.0-1127.19.1.el7.x86_64 成功构建
linux内核版本kernel-3.10.0-1160.2.2.el7.x86_64 构建失败 报错

(3)解决方法

安装较新的OVS版本 如2.12.0。

安装依赖包:

rpmbuild -bb --without check ~/rpmbuild/SOURCES/openvswitch-2.12.0/rhel/openvswitch_no_kmod.spec

安装:

yum -y localinstall ~/rpmbuild/RPMS/x86_64/openvswitch-2.12.0-1.x86_64.rpmsystemctl enable openvswitch
systemctl start openvswitch

检查服务是否启动:

systemctl is-active openvswitch

在已经安装低版本OVS后,如2.5.10。
可以直接安装高版本如2.12.0
安装完成需重启OpenVSwitch后 OVS服务替换为2.12.0 版本

systemctl restart openvswitch

原数据都会得到保留。

OVS 卸载:

卸载前保证 OVS上设置的网桥全部删除。

可直接使用命令 卸载。使用ssh连接,最好保证卸载OVS后ssh 还能连上,不然网络会中途断掉,连接失败,卸载也会终止。

yum -y remove openvswitch

2.virt-install未找到命令

(1)报错

(2)原因分析

软件未安装

(3)解决方法

安装软件。

yum install libguestfs-toolsyum install virt-install.noarch

3.如何删除自定义网络

(1)取消定义

# virsh net-undefine ovs01

(2)删除

# virsh net-destroy ovs01

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/215291.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

创建一个有阴影的threejs三维几何体

import * as THREE from "three" import { OrbitControls } from three/examples/jsm/controls/OrbitControlsconst width window.innerWidth; const height window.innerHeight;//创建场景 const scene new THREE.Scene(); scene.background new THREE.Color(#6…

LinuxBasicsForHackers笔记 --Python 脚本基础

添加Python模块 Python 有一个专门用于安装和管理 Python 包的包管理器&#xff0c;称为 pip&#xff08;Pip Installs Packages&#xff09;。由于我们在这里使用 Python 3&#xff0c;因此您将需要 Python 3 的 pip 来下载和安装软件包。默认情况下应包含 Pip&#xff0c;但…

vue前端访问Django channels WebSocket失败

现象 前端报错&#xff1a;SSH.vue:51 WebSocket connection to ‘ws://127.0.0.1:8000/server/terminal/120.59.88.26/22/1/’ failed: 后端报错&#xff1a;Not Found: /server/terminal/120.79.83.26/22/1/ 原因 django的版本与channels的版本不匹配&#xff08;django…

关于个人职业选择

职业选择&#xff0c;一直是个老生常谈的话题。这并不是一个容易做的决定。 让我们来看看AI怎么说。 首先是方向性的回答&#xff1a; 然后是一些具体的回答 我个人比较倾向于深耕网络安全。这是一个很有趣也是一个持续发展着的领域。 不知道关于这个事情你怎么看&#xff0…

在线学习平台-课程分页、用户管理、教师查询

在线学习平台------手把手教程&#x1f448; 用户管理 添加功能增强 新增属性 若依里的用户模块(SysUser)是没有课程这一属性的,要实现我们自己的课程分页查询功能 这个位置传入的实体类SysUser要加上classId,记得加上get、set方法 更改sql语句 ctrl 鼠标左键不断点进去…

DS二叉排序树之删除

Description 给出一个数据序列&#xff0c;建立二叉排序树&#xff0c;并实现删除功能 对二叉排序树进行中序遍历&#xff0c;可以得到有序的数据序列 Input 第一行输入t&#xff0c;表示有t个数据序列 第二行输入n&#xff0c;表示首个序列包含n个数据 第三行输入n个数据…

蓝桥杯周赛 第 1 场 强者挑战赛 6. 小球碰撞【算法赛】(思维题/最长上升子序列LIS)

题目 https://www.lanqiao.cn/problems/9494/learning/?contest_id153 思路来源 Aging代码 题解 二分时间t&#xff0c;第i个小球对应一个起点pi、终点pit*vi的区间&#xff0c;问题转化为&#xff0c; 选最多的区间&#xff0c;使得不存在区间包含&#xff08;即li<l…

微信小程序过滤器之计算当前时间差

微信小程序过滤器之计算当前时间差 前言一、wxs简介二、使用步骤1.定义2.使用 前言 最近遇到了一个需求&#xff0c;将小程序里面的具体时间2023-12-11 09:41:06转为当前时间差10小时前&#xff0c;这块可以使用js逻辑函数对数据进行处理&#xff0c;但这里我们采用微信小程序…

Error: Failed to resolve vue/compiler-sfc——vite项目启动报错——npm run serve

运行项目时&#xff0c;报错如下&#xff1a; Error: Failed to resolve vue/compiler-sfc 根据报错信息的提示&#xff1a;vue的版本必须大于3.2.25&#xff0c;经过查看package.json文件&#xff0c;可以看到vue的版本为3.2.36&#xff0c;是满足条件的。 因此考虑缓存问题&…

【OPNEGIS】Geoserver原地升级jetty,解决Apache HTTP/2拒绝服务漏洞 (CVE-2023-44487)

Geoserver是我们常用的地图服务器&#xff0c;在开源系统中的应用比较广泛。在实际环境中&#xff0c;我们可能会选用官方的二进制安装包进行部署&#xff0c;这样只要服务器上有java环境就可以运行&#xff0c;方便在现场进行部署。 1.问题来源 这次由于甲方一月一次的漏洞扫…

智能优化算法应用:基于阴阳对算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于阴阳对算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于阴阳对算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.阴阳对算法4.实验参数设定5.算法结果6.参考文…

Java - Mybatis的缓存机制、集成SpringBoot后缓存相关问题

mybaits提供一级缓存&#xff0c;和二级缓存 一级缓存&#xff08;默认开启&#xff09; 一级缓存是SqlSession级别的缓存。在操作数据库时需要构造 sqlSession对象&#xff0c;在对象中有一个(内存区域)数据结构&#xff08;HashMap&#xff09;用于存储缓存数据。不同的sqlSe…

STM32F407-14.3.1-01 时基单元

时基单元 可编程高级控制定时器的主要模块是一个 16 位计数器及其相关的自动重载寄存器。计数器可递增计数、递减计数或交替进行递增和递减计数。计数器的时钟可通过预分频器进行分频。 计数器、自动重载寄存器和预分频器寄存器可通过软件进行读写。即使在计数器运行时也可执行…

Python:核心知识点整理大全14-笔记

目录 ​编辑 7.2.2 让用户选择何时退出 parrot.py 7.2.3 使用标志 7.2.4 使用 break 退出循环 cities.py 7.2.5 在循环中使用 continue counting.py 7.2.6 避免无限循环 counting.py 7.3 使用 while 循环来处理列表和字典 7.3.1 在列表之间移动元素 confirmed_user…

数字图像处理(实践篇)二十二 使用opencv进行人脸、眼睛、嘴的检测

目录 1 xml文件 2 涉及的函数 3 实践 使用opencv进行人脸、眼睛、嘴的检测。 1 xml文件 方法① 下载 地址&#xff1a;https://github.com/opencv/opencv/tree/master/data/haarcascades 点击haarcascade_frontalface_default.xml文件 对着Raw右键&#xff0c;选择“链接…

【JVM从入门到实战】(二)字节码文件的组成

一、Java虚拟机的组成 二、字节码文件的组成 字节码文件的组成 – 应用场景 字节码文件的组成部分-Magic魔数 什么是魔数&#xff1f; Java字节码文件中的魔数 文件是无法通过文件扩展名来确定文件类型的&#xff0c;文件扩展名可以随意修改&#xff0c;不影响文件的内容。…

UE引擎 LandscapeGrass 实现机制分析(UE5.2)

前言 随着电脑和手机硬件性能越来越高&#xff0c;游戏越来越追求大世界&#xff0c;而大世界非常核心的一环是植被&#xff0c;目前UE5引擎提供给植被生成的主流两种方式为 手刷植被和LandscapeGrass(WeightMap程序化植被)。当然UE5.3推出新一代PCGFramework 节点程序化生成框…

MyBatis:缓存

MyBatis 缓存一级缓存二级缓存注 缓存 缓存&#xff0c;是数据交换的缓冲区&#xff08;临时保存数据的地方&#xff09;。即将数据&#xff08;数据一般为频繁查询且不易改变&#xff09;保存在计算机内存中&#xff0c;下次读取数据时直接从内存中获取&#xff0c;以避免频繁…

OpenAI接口调用示例

最近为公司做了一个ChatGPT工具&#xff0c;这里展示一下OpenAI接口的调用 前提条件 访问OpenAI官网&#xff08;国内需要翻墙&#xff09;的账号&#xff0c;需要sk 地址&#xff1a;https://platform.openai.com 依赖 使用开源工具调用OpenAI接口&#xff0c;依赖如下&am…

Vue3封装一个轮播图组件

先看效果 编写组件代码 CarouselChart.vue <template><div classimg-box><el-button clickpreviousImages v-ifprops.showBtn>←</el-button><div classimg><div styledisplay: flex;gap: 20px idmove><imgclassimg-item v-for(item…