当前位置: 首页 > news >正文

构建OVS网络

构建OVS网络

1. 配置虚拟机环境

(1)配置虚拟机交换机

1 创建一个名为br-xd的虚拟交换机。

# ovs-vsctl add-br br-xd

2 查询虚拟交换机。

# ovs-vsctl show

5a1cd870-fc31-4820-a7f4-b75c19450582

    Bridge br-xd

        Port br-xd

            Interface br-xd

                type: internal

3 确认组件安装。

在使用虚拟交换机之前首先确认TAP所需要的组件的组件是否安装。

#yum -y localinstall tunctl-1.5-26.14.x86_64.rpm (tunctl包上传至root目录)

4 创建TAP设备,创建前需要确认tun模块是否被加载。

# tunctl  -b -u root -t tap1

# tunctl  -b -u root -t tap2

5 设备连接到虚拟交换机。

# ovs-vsctl add-port br-xd tap1

# ovs-vsctl add-port br-xd tap2

6 查看是否添加成功。

# ovs-vsctl show

5a1cd870-fc31-4820-a7f4-b75c19450582

    Bridge br-xd

        Port "tap1"

            Interface "tap1"

        Port "tap2"

            Interface "tap2"

        Port br-xd

            Interface br-xd

                type: internal

启动TAP设备

# ip link set up tap1

# ip link set up tap2

(2)启动虚拟机

1 启动OVS1。

启动虚拟机之前首先创建两个镜像文件,拷贝本任务所提供的cirros-0.3.3-x86_64-disk.img为ovs1.img。

# cp -p  cirros-0.3.3-x86_64-disk.img ovs1.img

# /usr/libexec/qemu-kvm -drive file=ovs1.img -m 1024 -vnc :100 -net nic,macaddr=32:a9:76:d9:46:2b,model=virtio -net tap,ifname=tap1,script=no,downscript=no -name OVS1 -daemonize

2 启动OVS2。

启动虚拟机之前首先创建镜像文件,拷贝本任务所提供的cirros-0.3.3-x86_64-disk.img为ovs2.img。

# cp -p  cirros-0.3.3-x86_64-disk.img ovs2.img

# /usr/libexec/qemu-kvm -drive file=ovs2.img  -m 1024  -vnc :101 -net nic,macaddr=32:a9:76:d9:46:3a,model=virtio -net tap,ifname=tap2,script=no,downscript=no -name OVS2 -daemonize

2. 登陆虚拟主机配置地址

1 VNC登陆虚拟主机,查看虚拟机的VNC端口。

通过netstat -ntpl命令可以查询qemu-kvm对应的实例监听的端口。

# netstat -ntpl

Active Internet connections (only servers)

Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name   

tcp        0      0 0.0.0.0:111                 0.0.0.0:*                   LISTEN      1092/rpcbind        

tcp        0      0 0.0.0.0:6000                0.0.0.0:*                   LISTEN      7173/qemu-kvm       

tcp        0      0 0.0.0.0:6001                0.0.0.0:*                   LISTEN      7201/qemu-kvm    

2 VNC登陆虚拟机。

通过查询虚拟机的VNC端口可以知道,OVS1虚拟机的端口为6000,OVS2的端口为6001,利用VNC Viewer登陆虚拟机。

登陆OVS1虚拟机,配置服务器地址为192.168.1.131:6000,如图4-10所示。配置完成后登陆主机,如图4-11所示。

图4-10 OVS1 VNC Viewer配置

图4-11 登陆OVS1虚拟机

登陆OVS2虚拟机,配置服务器地址为192.168.1.131:6001,如图4-12所示。配置完成后登陆主机,如图4-13所示。

图4-12 OVS2 VNC Viewer配置

图4-13 登陆OVS1 虚拟机

3 修改IP地址。

在OVS1上修改eth0的IP地址为10.0.1.2/24。

$sudo ifconfig eth0 10.0.1.2 netmask 255.255.255.0

在OVS2上修改eth0的IP地址为10.0.1.3/24。

# sudo ifconfig eth0 10.0.1.3 netmask 255.255.255.0

修改完成后检查两个节点之间的连通性。

# ping 10.0.1.3 -c 4 -I 10.0.1.2

PING 10.0.1.20 (10.0.1.20) from 10.0.2:56(84) bytes of data.

64 bytes from 10.0.1. 3: icmp_seq=1 ttl=255 time=1.04 ms

64 bytes from 10.0.1. 3: icmp_seq=2 ttl=255 time=1.13 ms

64 bytes from 10.0.1. 3: icmp_seq=3 ttl=255 time=0.438 ms

64 bytes from 10.0.1. 3: icmp_seq=4 ttl=255 time=0.134 ms

--- 10.0.1. 3ping statistics ---

4 packets transmitted, 4 received, 0% packet loss, time 3003ms

rtt min/avg/max/mdev = 0.134/0.687/1.138/0.417 ms

3. OVS交换机操作

1 查询网桥信息。

在宿主机上查看Port信息, 确认虚拟机对应的Port ID

# ovs-ofctl show br-xd

OFPT_FEATURES_REPLY (xid=0x2): dpid:00005e440f43e144

n_tables:254, n_buffers:256

capabilities: FLOW_STATS TABLE_STATS PORT_STATS QUEUE_STATS ARP_MATCH_IP

actions: output enqueue set_vlan_vid set_vlan_pcp strip_vlan mod_dl_src mod_dl_dst mod_nw_src mod_nw_dst mod_nw_tos mod_tp_src mod_tp_dst

 1(tap1): addr:16:40:8d:ed:76:32

     config:     0

     state:      0

     current:    10MB-FD COPPER

     speed: 10 Mbps now, 0 Mbps max

 2(tap2): addr:8a:37:2f:e4:9b:b2

     config:     0

     state:      LINK_DOWN

     current:    10MB-FD COPPER

     speed: 10 Mbps now, 0 Mbps max

 LOCAL(br-xd): addr:5e:44:0f:43:e1:44

     config:     PORT_DOWN

     state:      LINK_DOWN

     speed: 0 Mbps now, 0 Mbps max

OFPT_GET_CONFIG_REPLY (xid=0x4): frags=normal miss_send_len=0

2 查看流表信息。

# ovs-ofctl dump-flows br-xd

NXST_FLOW reply (xid=0x4):

 cookie=0x0, duration=124323.206s, table=0, n_packets=3129, n_bytes=201115, idle_age=1, hard_age=65534, priority=0 actions=NORMAL

3 检查OVS流表端口。

# ovs-ofctl  dump-ports br-xd

OFPST_PORT reply (xid=0x2): 3 ports

  port 10: rx pkts=6172, bytes=590184, drop=0, errs=0, frame=0, over=0, crc=0

           tx pkts=6171, bytes=590086, drop=12, errs=0, coll=0

  port  8: rx pkts=8576, bytes=759677, drop=0, errs=0, frame=0, over=0, crc=0

           tx pkts=7278, bytes=684136, drop=18, errs=0, coll=0

  port LOCAL: rx pkts=139, bytes=14672, drop=0, errs=0, frame=0, over=0, crc=0

           tx pkts=687, bytes=48528, drop=0, errs=0, coll=0

4 流表删除操作。

由流表端口可以看出port8和port10为OVS1和OVS2两台KVM虚拟机的端口,从流表信息还可以看出由一条流表对应的规则actions为NORMAL,就是按普通交换机处理数据包。这里添加一条流,将来自OVS1对应Port的数据包全部丢弃,完成后再次检查OVS的数据流表信息。

# ovs-ofctl add-flow br-xd "priority=10,in_port=8,actions=drop"

# ovs-ofctl dump-flows br-xd

NXST_FLOW reply (xid=0x4):

 cookie=0x0, duration=175718.172s, table=0, n_packets=17735, n_bytes=1576239, idle_age=0, hard_age=65534, priority=0 actions=NORMAL

 cookie=0x0, duration=202.882s, table=0, n_packets=229, n_bytes=11410, idle_age=0, priority=10,in_port=8 actions=drop

这时再次尝试检查两个节点之间的连通性。

# ping 10.0.1.3 -c 4 -I 10.0.1.2

PING 10.0.1. 3 (10.0.1.20) from 10.0. 2:56(84) bytes of data.

--- 10.0.1. 3ping statistics ---

4 packets transmitted, 0 received, 100% packet loss

5 恢复流表操作。

删除添加的流

# ovs-ofctl del-flows br-xd in_port=8

删除完成后再次检查节点之间的连通性。

# ping 10.0.1.3 -c 4 -I 10.0.1.2

PING 10.0.1.20 (10.0.1.20) from 10.0.2:56(84) bytes of data.

64 bytes from 10.0.1. 3: icmp_seq=1 ttl=255 time=1.04 ms

64 bytes from 10.0.1. 3: icmp_seq=2 ttl=255 time=1.13 ms

64 bytes from 10.0.1. 3: icmp_seq=3 ttl=255 time=0.438 ms

64 bytes from 10.0.1. 3: icmp_seq=4 ttl=255 time=0.134 ms

--- 10.0.1. 3ping statistics ---

4 packets transmitted, 4 received, 0% packet loss, time 3003ms

rtt min/avg/max/mdev = 0.134/0.687/1.138/0.417 ms

相关文章:

构建OVS网络

构建OVS网络 1. 配置虚拟机环境 (1)配置虚拟机交换机 1 创建一个名为br-xd的虚拟交换机。 # ovs-vsctl add-br br-xd 2 查询虚拟交换机。 # ovs-vsctl show 5a1cd870-fc31-4820-a7f4-b75c19450582 Bridge br-xd Port br-xd …...

【Python】万能之王 Lambda 函数详解

Python 提供了非常多的库和内置函数。有不同的方法可以执行相同的任务,而在 Python 中,有个万能之王函数:lambda 函数,它可以以不同的方式在任何地方使用。今天云朵君将和大家一起研究下这个万能之王! Lambda 函数简介…...

手把手教你怎么搭建自己的AI数字人直播间?帮你24小时不间断直播卖货

在搭建AI数字人直播间之前,您需要了解数字人技术。 一、什么是AI数字人、数字人直播间? 数字人是一种由人工智能技术构建的虚拟人物,其外貌、行为、语言等特征与真实人物相似,可以与人进行互动。数字人可以通过语音合成、人脸识…...

MySQL性能监控全掌握,快来get关键指标及采集方法!

数据库中间件监控实战,MySQL中哪些指标比较关键以及如何采集这些指标了。帮助提早发现问题,提升数据库可用性。 1 整体思路 监控哪类指标? 如何采集数据? 第10讲监控方法论如何落地? 这些就可以在MySQL中应用起来。…...

sed进阶之保留空间和排除命令

shell脚本编程系列 保留空间 模式空间(pattern space)是一块活跃的缓冲区,在sed编辑器执行命令时保存着待检查的文本,但它并不是sed编辑器保存文本的唯一空间。sed编辑器还有另一块称作保留空间(hold space&#xff0…...

21安徽练习

题目分为4部分 APK 集群 流量 exe 我尽量都做一下,逆向不是很会,就当提升自己。 [填空题]请获取app安装包的SHA256校验值(格式:不区分大小写)(10分) e15095d49efdccb0ca9b2ee125e4d8136cac5…...

【VAR | 时间序列】应用VAR模型时的15个注意点

一、前言 向量自回归(VAR,Vector Auto regression)常用于预测相互联系的时间序列系统以及分析随机扰动对变量系统的动态影响。 VAR方法通过把系统中每一个内生变量,作为系统中所有内生变量的滞后值的函数来构造模型,从而回避了结构化模型的…...

校招在线测评题目汇总

图形找规律题 https://blog.csdn.net/mxj1428295019/article/details/129627461https://blog.csdn.net/Yujian2563/article/details/124266574?spm1001.2101.3001.6650.2&utm_mediumdistribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-2-124266574-blo…...

『python爬虫』05. requests模块入门(保姆级图文)

目录 安装requests1. 抓取搜狗搜索内容 requests.get2. 抓取百度翻译数据 requests.post3. 豆瓣电影喜剧榜首爬取4. 关于请求头和关闭request连接总结 欢迎关注 『python爬虫』 专栏,持续更新中 欢迎关注 『python爬虫』 专栏,持续更新中 安装requests …...

WPF超好用的框架Prism入门使用,上位机赶紧学起来!

Prism简介 WPF框架Prism是一种用于开发模块化、可重用和可测试的WPF应用程序的框架。它提供了一种简单而强大的方式来管理复杂应用程序的代码和构建高度可扩展的应用程序。 如何学习Prism框架 如果您想使用Prism框架来开发WPF应用程序,需要学习以下几个方面&…...

十个机器学习应用实例

一、在Kaggle上举办的一个竞赛,名为“Tabular Playground Series - Aug 2021”。该竞赛旨在预测房屋销售价格,数据集包含了79个特征和一个目标变量。参赛者需要训练一个模型,能够预测测试集中房屋的销售价格。 该竞赛的获胜者使用了多个AI模型…...

【Redis17】Redis进阶:管道

Redis进阶:管道 管道是啥?我们做开发的同学们经常会在 Linux 环境中用到管道命令,比如 ps -ef | grep php 。在之前学习 Laravel框架时的 【Laravel6.4】管道过滤器https://mp.weixin.qq.com/s/CK-mcinYpWCIv9CsvUNR7w 这篇文章中&#xff0c…...

Django项目页面样式如何“传给”客户端浏览器

前言 django项目在视图函数中借助render函数可以返回HTML页面,但是HTML页面中如果引入了外部CSS文件或者JavaScript文件在浏览器页面无法加载,因此就必须有一种方式能够将HTML文档中引入的外部文件能够在客户端浏览器上加载,这种方式就是配置…...

python 进程间通信 Queue()、Pipe()、manager.list()、manager.dict()、manager.Queue()

👨‍💻个人简介: 深度学习图像领域工作者 🎉总结链接: 链接中主要是个人工作的总结,每个链接都是一些常用demo,代码直接复制运行即可。包括: &am…...

你想要的【微前端】都在这里了! | 京东云技术团队

作者:京东零售 郑炳懿 开篇: 如果你不知道微前端是什么,或者不知道微前端能解决什么问题,那么你可能不需要微前端。 在我看来,对于每一个没有使用过的新技术,都应该有以下几个过程: 1、调研…...

人生若只如初见,你不来看看Django吗

前言 本文介绍python三大主流web框架之一的Django框架的基本使用,如何创建django项目,如何运行django项目以及django项目的目录结构,另外django又是如何返回不同的数据和页面? python三大主流web框架 Python有三大主流的web框架…...

项目人力资源管理

项目人力资源管理的 4 个过程:规划人力资源管理、组建项目团队、建设项目团队、管理项目团队等内容 单项选择题、案例分析题 人力资源管理领域输入、输出、工具和技术表: 过程名输入工具和技术输出编写项目人力资源计划 项目管理计划活动资源需求事业…...

提供接口给第三方调用,应该注意什么

1.如果我们要提供一个接口给第三方调用,首先我们需要考虑的就是接口安全,一定要做鉴权,至于鉴权的方式:大家可以在网上自行查找,今天我主要记录如何编写一个既能能支持并发的,且不会影响到我们自身业务的的…...

ESL设计概述

‍‍ ‍‍前言 随着芯片面临着应用场景丰富多变、集成功能模块越来越多、片内通信及模块间接口越来越复杂、设计规模越来越大以及PPA要求越来越高的需求,芯片设计方法面临越来越大的挑战。架构的合理性、完备性和一致性很大程度上决定了芯片设计的成败。基于同样的I…...

探究C语言数组的奥秘:大小可省略的定义、内存存储、数组名、传参、指针遍历、数组指针和指针数组、柔性数组等

也许你认为,C语言中的数组非常好理解,就是把一组相同类型的元素存储在同一块空间里。但是你可能并没有真正理解数组的本质,不信的话请回答一下下面的几个小问题,如果你能非常清晰的回答这些问题,那么你对C语言中的数组…...

python3 强制使用任意父级相对导入,越过python相对导入限制,拒绝 ImportError

前言 单纯不喜欢 python 对 点开头的包的限制,好麻烦,遂写了本包,来解决这个问题启用本模块后,你可以随时使用 单个点来导入当前目录的模块,也可以使用多个 点导入多级父目录内的模块,而不会报错烦人的模块…...

面了一个4年经验的测试工程师,自动化都不会也要15k,我也是醉了····

在深圳这家金融公司也待了几年,被别人面试过也面试过别人,大大小小的事情也见识不少,今天又是团面的一天, 一百多个人都聚集在一起,因为公司最近在谈项目出来面试就2个人,无奈又被叫到面试房间。 整个过程…...

Java 实现 YoloV7 人体姿态识别

1 OpenCV 环境的准备 这个项目中需要用到 opencv 进行图片的读取与处理操作,因此我们需要先配置一下 opencv 在 java 中运行的配置。 首先前往 opencv 官网下载 opencv-4.6 :点此下载;下载好后仅选择路径后即可完成安装。 此时将 opencv\b…...

跨越屏幕:桌面PC端的多端开发框架介绍

目前,随着互联网和移动互联网的发展,多端开发框架已经成为越来越多开发者更好的选择。主要有以下几个方面的前景: 跨平台开发需求不断增加:由于不同平台和设备的差异性,开发人员需要使用不同的编程语言和开发工具来为各…...

高效学习方法和工具推荐,让你事半功倍!

本文介绍了五种高效学习方法,包括制定详细的学习计划、集中注意力、不断复习、采用多种学习方式和利用小休息。同时,还推荐了五个高效学习工具和平台,包括Coursera、Duolingo、Quizlet、Khan Academy和Anki,让你在学习中事半功倍&…...

查看Docker容器中RabbitMQ的密码

要查看Docker容器中RabbitMQ的密码,可以尝试以下几个步骤: 1. 查看容器运行时的环境变量 在Docker容器中,可以通过环境变量来设置RabbitMQ的用户名和密码。因此,可以使用以下命令查看容器的环境变量: docker inspect…...

探索Qt线程编程的奥秘:多角度深入剖析

探索Qt线程编程的奥秘:多角度深入剖析 一、Qt线程编程基础(Qt Threading Basics)1.1 线程概念与基本概念(Thread Concepts and Fundamentals)1.2 Qt线程类简介:QThread(Introduction to Qt Thre…...

【R语言】鉴于计算10亿以内训练模型记录for循环的加速

文章目录 1 前言2 几个循环2.1 100以内的和2.2 100以内奇数和/偶数和 3 多重循环3.1 向量化3.2 合并循环3.3 apply函数3.4 矩阵运算3.5 foreach分解任务 4 讨论 1 前言 笔者主力机是MBAM1芯片(8256),某个下午巩固循环突然思考到个问题&#…...

C++类和对象 ——构造函数

C拷贝构造函数详解 什么是拷贝构造函数?拷贝构造函数的特征默认拷贝构造函数为什么需要显示定义构造函数?拷贝构造函数的调用场景什么时候不需要自己定义拷贝构造函数 什么是拷贝构造函数? 在现实生活中,拷贝构造函数就好像我们上…...

第2章-分治法

第2章-分治法 总分:100分 得分:20.0分 1 . 多选题 中等 10分 有关以下代码,说法正确的是( ABCE) def BinarySearch(s, x, low, high):if (low > high):return -1middle (low high) / 2if (x s[mid…...

网站建设公司官网/百度指数查询平台

使用教程浏览器:ie编程语言:js使用ActiveXObject,该对象是微软的私有拓展名, 只在微软的IE浏览器上支持。指定打印机进行打印,是先将指定打印机设置成默认打印机,打印完成后,再恢复原来的打印机。//打印条码…...

学校网站建设情况/上海企业seo

量化策略开发,高质量社群,交易思路分享等相关内容 『正文』 ˇ 大家好,今天我们分享第11期策略——跟踪目标出场自适应切换策略。本期策略是2022年度倒数第2期策略,2023年度松鼠俱乐部内容会更加丰富,12月出预告敬请…...

可以做盗版漫画网站吗/网站制作建设

使用 ThreadPoolExecutor表示一个线程池。Executors类则扮演着线程池工厂的角色,通过Executors可以获取特定功能的线程池Executors工厂创建线程池普通线程池public static ExecutorService newFixedThreadPool(int nThreads)public static ExecutorService newFixe…...

如何制作自己的网址链接/手机优化是什么意思

题目背景 盛况空前的足球赛即将举行。球赛门票售票处排起了球迷购票长龙。 按售票处规定,每位购票者限购一张门票,且每张票售价为50元。在排成长龙的球迷中有N个人手持面值50元的钱币,另有N个人手持面值100元的钱币。假设售票处在开始售票时…...

wordpress 用户切换主题/网页模板建站系统

选择那个表右键- >Properties- >Columns- >Customize Columns and Filter(或直接用快捷键CtrlU)- >Comment(前面打勾)- >OK转载于:https://www.cnblogs.com/zgqys1980/archive/2012/07/09/2582474.html...

印度做批发的网站有哪些/站长之家app下载

***********************************************声明************************************************ 原创作品,出自 “深蓝的blog” 博客, 欢迎转载,转载时请务必注明出处(http://blog.csdn.net/huangyanlong)&…...