常见OVS网桥及其链接接口详解
目录
- 引言
- OVS简介
- 常见OVS网桥
- QBR(qbr)
- PLY网桥
- br-int
- br-tun
- br-router
- brcps
- 常见网桥链接接口
- QVO
- QVI
- QVM
- Patch
- 网桥和接口的工作原理
- 应用场景
- 虚拟化环境
- 数据中心网络
- 云计算平台
1. 引言
开放虚拟交换机(Open vSwitch,简称OVS)是一种高性能、多层虚拟交换机,旨在用于大规模虚拟化环境和云计算环境。OVS不仅支持标准的交换机功能,还提供对高级功能(如VLAN、流量控制和监控)的支持。在OVS中,网桥(Bridge)和链接接口(Interface)是两个核心概念。本博文将详细介绍常见的OVS网桥及其链接接口,帮助读者更好地理解和使用OVS。
2. OVS简介
开放虚拟交换机(OVS)是一个开源的多层虚拟交换机,广泛用于各种虚拟化平台,如KVM、Xen和Docker。OVS的设计目标是提供高性能和高可用性的网络功能,并且能够与现有的网络管理工具和协议集成。OVS支持多种功能,包括但不限于VLAN、QoS、流量镜像和负载均衡。
3. 常见OVS网桥
在OVS中,网桥是虚拟网络设备的核心组件,它们用于连接虚拟机、物理接口和其他网桥。以下是一些常见的OVS网桥:
3.1 QBR(qbr)
QBR是一种特殊类型的OVS网桥,通常用于虚拟机与外部网络之间的通信。在Neutron(OpenStack的网络服务)中,QBR网桥用于管理虚拟机接口。
定义与原理:
- 定义:QBR网桥是一个虚拟交换机,用于连接虚拟机的虚拟接口(veth)和主机的虚拟接口(tap)。
- 原理:QBR网桥通过虚拟接口连接虚拟机和物理网络,实现数据包的转发和处理。
应用场景:
- 虚拟化环境:QBR网桥通常用于OpenStack Neutron中,以管理和配置虚拟机的网络接口。
- 数据中心:在数据中心中,QBR网桥用于确保虚拟机可以与外部网络通信。
3.2 PLY网桥
PLY网桥是一种常见的OVS网桥类型,通常用于连接虚拟机和其他虚拟网络设备。PLY网桥的命名方式通常为“ply-”前缀,后跟一串唯一的标识符。
定义与原理:
- 定义:PLY网桥是一个虚拟交换机,用于连接虚拟机和其他虚拟网络设备。
- 原理:PLY网桥通过内部接口(internal)和补丁接口(patch)连接虚拟机和其他网桥,实现网络数据包的转发和处理。
应用场景:
- 虚拟化环境:PLY网桥常用于KVM和Xen等虚拟化平台中,以连接和管理虚拟机的网络。
- 云计算平台:在OpenStack等云计算平台中,PLY网桥用于实现虚拟机之间的网络通信。
3.3 br-int
br-int(内部网桥)是OpenStack中Neutron服务的核心组件之一。它用于管理虚拟机之间的内部网络通信。
定义与原理:
- 定义:br-int是一个内部网桥,用于管理虚拟机之间的内部网络通信。
- 原理:br-int网桥通过内部接口和补丁接口连接虚拟机,实现虚拟机之间的数据包转发。
应用场景:
- 虚拟化环境:br-int网桥用于OpenStack Neutron中,以管理和配置虚拟机的内部网络。
- 数据中心:在数据中心中,br-int网桥用于确保虚拟机之间的高效网络通信。
3.4 br-tun
br-tun(隧道网桥)是OpenStack中Neutron服务的另一个核心组件。它用于管理虚拟机之间的隧道通信,支持VXLAN和GRE等隧道协议。
定义与原理:
- 定义:br-tun是一个隧道网桥,用于管理虚拟机之间的隧道通信。
- 原理:br-tun网桥通过隧道接口(如VXLAN、GRE)连接虚拟机,实现跨主机的隧道通信。
应用场景:
- 虚拟化环境:br-tun网桥用于OpenStack Neutron中,以实现虚拟机之间的隧道通信。
- 数据中心:在数据中心中,br-tun网桥用于跨主机的网络通信,确保高效的数据传输。
3.5 br-router
br-router是一个特殊的OVS网桥,通常用于虚拟路由器的实现。它管理虚拟机和外部网络之间的路由功能。
定义与原理:
- 定义:br-router是一个用于实现虚拟路由器功能的网桥。
- 原理:br-router网桥通过内部接口和补丁接口连接虚拟机和外部网络,实现数据包的路由和转发。
应用场景:
- 虚拟化环境:br-router网桥用于OpenStack Neutron中,以实现虚拟机与外部网络之间的路由。
- 云计算平台:在云计算平台中,br-router网桥用于管理虚拟机的外部网络访问。
3.6 brcps
brcps是一个用于管理计算节点和物理网络之间通信的OVS网桥,通常用于OpenStack中的计算节点。
定义与原理:
- 定义:brcps是一个管理计算节点与物理网络通信的网桥。
- 原理:brcps网桥通过物理接口和虚拟接口连接计算节点和物理网络,实现数据包的转发和处理。
应用场景:
- 虚拟化环境:brcps网桥用于OpenStack中,以管理计算节点与物理网络之间的通信。
- 数据中心:在数据中心中,brcps网桥用于确保计算节点与物理网络之间的高效通信。
4. 常见网桥链接接口
在OVS中,网桥链接接口是实现网桥之间和网桥与虚拟机之间通信的重要组件。以下是一些常见的OVS网桥链接接口:
4.1 QVO
QVO(qvo接口)是OVS中的虚拟接口,用于连接虚拟机和OVS网桥。
定义与原理:
- 定义:QVO接口是一种虚拟接口,用于连接虚拟机和OVS网桥。
- 原理:QVO接口通过虚拟接口将虚拟机连接到OVS网桥,实现数据包的转发和处理。
应用场景:
- 虚拟化环境:QVO接口用于将虚拟机连接到OVS网桥,实现虚拟机的网络通信。
- 云计算平台:在OpenStack等云计算平台中,QVO接口用于实现虚拟机的网络连接。
4.2 QVI
QVI(qvi接口)是OVS中的虚拟接口,通常用于连接虚拟机的内部接口。
定义与原理:
- 定义:QVI接口是一种虚拟接口,用于连接虚拟机的内部接口。
- 原理:QVI接口通过虚拟接口将虚拟机的内部接口连接到OVS网桥,实现内部网络的通信。
应用场景:
- 虚拟化环境:QVI接口用于连接虚拟机的内部接口,实现虚拟机内部的网络通信。
- 云计算平台:在OpenStack等云计算平台中,QVI接口用于实现虚拟机内部网络的连接。
4.3 QVM
应用场景:
- 虚拟化环境:QVM接口用于管理虚拟机的虚拟接口,实现虚拟机的网络通信。
- 云计算平台:在OpenStack等云计算平台中,QVM接口用于实现虚拟机的网络管理和配置。
4.4 Patch
Patch接口是OVS中一种特殊的虚拟接口类型,用于连接不同的OVS网桥。Patch接口通常成对出现,一对Patch接口将两个网桥连接在一起。
定义与原理:
- 定义:Patch接口是一种用于连接两个OVS网桥的虚拟接口。
- 原理:Patch接口通过虚拟接口将两个网桥连接在一起,实现数据包的无缝转发。
应用场景:
- 虚拟化环境:Patch接口用于连接不同的OVS网桥,以实现跨网桥的网络通信。
- 数据中心:在数据中心中,Patch接口用于连接多个OVS网桥,构建复杂的网络拓扑结构。
5. 网桥和接口的工作原理
OVS网桥和接口的工作原理涉及多个方面,包括数据包的转发、过滤和处理。以下是一些关键原理:
5.1 数据包转发
OVS网桥通过流表(Flow Table)来决定如何处理和转发数据包。每个流表条目包含匹配条件和动作,当一个数据包到达网桥时,网桥会根据流表条目对其进行处理。
5.2 数据包过滤
OVS网桥可以通过流表条目实现数据包的过滤,例如,可以根据源IP地址、目标IP地址、端口号等进行匹配和过滤。
5.3 数据包处理
OVS网桥还支持高级的数据包处理功能,如VLAN标记、QoS(质量服务)策略、流量镜像等。这些功能可以通过配置流表条目来实现。
6. 应用场景
OVS网桥和接口在多个领域都有广泛的应用,以下是一些常见的应用场景:
6.1 虚拟化环境
在虚拟化环境中,OVS网桥用于连接和管理虚拟机的网络接口,实现虚拟机之间和虚拟机与外部网络之间的通信。
- KVM和Xen:OVS网桥常用于KVM和Xen等虚拟化平台,以连接和管理虚拟机的网络。
- Docker:在Docker容器环境中,OVS网桥用于管理容器之间的网络通信。
6.2 数据中心网络
在数据中心网络中,OVS网桥用于构建复杂的网络拓扑结构,支持高性能和高可用性的网络通信。
- 网络虚拟化:OVS网桥用于实现网络虚拟化,将物理网络抽象为虚拟网络,提供灵活的网络管理。
- 流量管理:OVS网桥支持流量控制和负载均衡,确保数据中心网络的高效运行。
6.3 云计算平台
在云计算平台中,OVS网桥是实现虚拟网络的重要组件,支持虚拟机的网络连接和管理。
- OpenStack:在OpenStack中,OVS网桥用于Neutron服务,以实现虚拟机的网络配置和管理。
- AWS和GCP:在AWS和GCP等云平台中,OVS网桥用于支持虚拟机和容器的网络连接。
希望这篇文章对各位宝子有帮助
相关文章:
常见OVS网桥及其链接接口详解
目录 引言OVS简介常见OVS网桥 QBR(qbr)PLY网桥br-intbr-tunbr-routerbrcps常见网桥链接接口 QVOQVIQVMPatch网桥和接口的工作原理应用场景 虚拟化环境数据中心网络云计算平台 1. 引言 开放虚拟交换机(Open vSwitch,简称OVS&…...
创建最最最纯净 Windows 11/10 系统镜像!| 全网独一份
前期准备工作 1.配置系统应答文件:【点击前往】 2.系统镜像编辑器: 【点击下载】 3.Windows 系统镜像官方下载: 【Windows 11】、【Windows 10】【官方密钥】 4.翻译工具 【GitHub】 5.详细的设置教程 5.1先打开配置系统应答文件&#…...
带你学会Git必会操作
文章目录 带你学会Git必会操作1Git的安装2.Git基本操作2.1本地仓库的创建2.2配置本地仓库 3.认识一些Git的基本概念3.1操作流程: 4.一些使用场景4.1添加文件场景一4.2查看git文件4.3修改文件4.4Git版本回退4.5git撤销修改 5.分支管理5.1查看分支5.2创建本地分支5.3切…...
clickhouse处理readonly报错
1,clickhouse执行 SYSTEM RESTORE REPLICA db_com.dwd_com_t_judge_result_local; SYSTEM RESTORE REPLICA db_com.dwd_com_t_judge_result_local Query id: 70669be0-eef8-41da-b761-4980ce48ece2 0 rows in set. Elapsed: 0.001 sec. Received exception fro…...
使用git命令行的方式,将本地项目上传到远程仓库
在国内的开发环境中,git的使用是必不可少的。Git 是一款分布式版本控制系统,用于有效管理和追踪文件的变更历史及协作开发。本片文章就来介绍一下怎样使用git命令行的方式,将本地项目上传到远程仓库,虽然现在的IDE中基本都配置了g…...
jetbrains InterlliJ IDEA 2024.1 版本最新特性一览: Java 相关内容
简简单单 Online zuozuo:欢迎商业合作 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo :本心、输入输出、结果 简简单单 Online zuozuo :联系我们:VX :tja6288 / EMAIL: 347969164@qq.com 文章目录 jetbrains InterlliJ …...
百日筑基第三十四天-JAVA中的强/软/弱/虚引用
百日筑基第三十四天-JAVA中的强/软/弱/虚引用 Java对象的引用被划分为4种级别,分别为强引用、软引用、弱引用以及虚引用。帮助程序更加灵活地控制对象的生命周期和JVM进行垃圾回收。 强引用 强引用是最普遍的引用,一般把一个对象赋给一个引用变量&…...
C语言100基础拔高题(3)
1.利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。 解题思路:通过反复调用一个打印最后一个元素的函数,来实现此功能。源代码如下: #include<stdio.h> void oposize(char str[], int len); int main() {//利…...
AV1技术学习:Constrained Directional Enhancement Filter
CDEF允许编解码器沿某些(可能是倾斜的)方向应用非线性消阶滤波器。它以88为单位进行。如下图所示,通过旋转和反射所示的三个模板来定义八个预设方向。 Templates of preset directions and their associated directions. The templates correspond to directions of…...
C++的STL简介(一)
目录 1.什么是STL 2.STL的版本 3.STL的六大组件 4.string类 4.1为什么学习string类? 4.2string常见接口 4.2.1默认构造 编辑 4.2.2析构函数 Element access: 4.2.3 [] 4.2.4迭代器 编辑 auto 4.2.4.1 begin和end 4.2.4.2.regin和rend Capacity: 4.2.5…...
DNS劫持
目录 一、DNS的基本概念 二、DNS劫持的工作原理 三、DNS劫持的影响 四、DNS劫持的防范措施 DNS劫持:一种网络安全威胁的深入分析 在当今网络日益发达的时代,互联网已经成为了人们日常生活中不可或缺的一部分。然而,随着网络技术的进步&am…...
Centos7解决网关ens33的静态地址配置
原因复现: 我登录一段时间之后我ens33的网关ip地址发生了改变 原ip地址配置 现有地址: 根据文心一言提示 修改配置文件 sudo vi /etc/sysconfig/network-scripts/ifcfg-ens33 我的原配置 [rootlocalhost ~]# sudo vi /etc/sysconfig/network-scripts/ifcfg-ens33 TYPE"…...
python中常用于构建cnn的库有哪些
在Python中,有多种库可用于构建卷积神经网络(CNN)。以下是几种常用的库: 1. TensorFlow TensorFlow是一个开源深度学习框架,由Google Brain团队开发。它支持构建和训练各种神经网络模型,包括卷积神经网络。…...
【前端 17】使用Axios发送异步请求
Axios 简介与使用:简化 HTTP 请求 在现代 web 开发中,发送 HTTP 请求是一项常见且核心的任务。Axios 是一个基于 Promise 的 HTTP 客户端,适用于 node.js 和浏览器,它提供了一种简单的方法来发送各种 HTTP 请求。本文将介绍 Axio…...
Unity Android接入SDK 遇到的问题
1. buildtools、platformtools、commandline tools 以及compiled sdk version、buildtools sdk version、target sdk version 的说明 Android targetSdkVersion了解一下 - 简书 2. 查看.class 和.jar文件 jd_gui 官网地址: 下载jd_gui 工具 ,或者 idea 下…...
基于深度学习的复杂策略学习
基于深度学习的复杂策略学习(Complex Strategy Learning)是通过深度学习技术,特别是强化学习和模仿学习,来开发和优化解决复杂任务的策略。这类技术广泛应用于自动驾驶、游戏AI、机器人控制和金融交易等领域。以下是对这一领域的系…...
【Golang 面试 - 进阶题】每日 3 题(一)
✍个人博客:Pandaconda-CSDN博客 📣专栏地址:http://t.csdnimg.cn/UWz06 📚专栏简介:在这个专栏中,我将会分享 Golang 面试中常见的面试题给大家~ ❤️如果有收获的话,欢迎点赞👍收藏…...
周报 Week 3:
补题链接: Week 3 DAY 1-CSDN博客 河南萌新联赛2024第(二)场:南阳理工学院-CSDN博客 Week 3 DAY 5:-CSDN博客 Week 3 DAY 6-CSDN博客 这周题单是动态规划——(背包问题,线性dp):…...
开源消息队列比较
目录 1. Apache Kafka 1.1安装步骤 1.1.1使用Docker安装 1.1.1手动安装 1.2 C#使用示例代码 1.2.1 安装Confluent.Kafka 1.2.2生产者代码示例 1.2.3消费者代码示例 1.3特点 1.4使用场景 2. RabbitMQ 2.1安装步骤 2.1.1使用Docker安装 2.1.2手动安装 2.2 C#使用示…...
【前端逆向】最佳JS反编译利器,原来就是chrome!
有时候需要反编译别人的 min.js。 比如简单改库、看看别人的 min,js 干了什么,有没有重复加载?此时就需要去反编译Javascript。 Vscode 里面有一些反编译插件,某某Beautify等等。但这些插件看人品,运气不好搞的话,反…...
微信小程序根据动态权限展示tabbar
微信小程序自定义 TabBar 后根据权限动态展示tabbar 在微信小程序开发中,自定义 TabBar 可以让应用更具灵活性和个性化。特别是在用户根据不同权限展示不同的 TabBar 内容时,正确的实现方法能够提升用户体验。本篇文章将分享如何使用事件总线实现权限变动时动态更新自定义 T…...
开源安全信息和事件管理(SIEM)平台OSSIM
简介 OSSIM,开源安全信息和事件管理(SIEM)产品,提供了经过验证的核心SIEM功能,包括事件收集、标准化和关联。 OSSIM作为一个开源平台,具有灵活性和可定制性高的优点,允许用户根据自己的特定需…...
【DP】01背包
算法-01背包 前置知识 DP 思路 01背包一般分为两种,不妨叫做价值01背包和判断01背包。 价值01背包 01背包问题是这样的一类问题:给定一个背包的容量 m m m 和 n n n 个物品,每个物品有重量 w w w 和价值 v v v,求不超过背…...
50、PHP 实现选择排序
题目: PHP 实现选择排序 描述: n个记录的文件的直接选择排序可经过n-1趟直接选择排序得到有序结果:(1)初始状态:无序区为R[1…n],有序区为空。(2)第1趟排序在无序区R[1…n]中选出关键字最小的记录R[k],将…...
17.延迟队列
介绍 延迟队列,队列内部是有序的,延迟队列中的元素是希望在指定时间到了以后或之前取出和处理。 死信队列中,消息TTL过期的情况其实就是延迟队列。 使用场景 1.订单在十分钟内未支付则自动取消。 2.新创建的店铺,如果十天内没…...
KCache-go本地缓存,支持本地缓存过期、缓存过期自维护机制。
GitHub - kocor01/kcache: go 本地缓存解决方案,支持本地缓存过期、缓存过期自维护机制。 最近系统并发很高,单接口10W的 QPS,对 redis 压力很大,大量的热KEY导致 redis 分片CPU资源经常告警。计划用 go 本地缓存缓解 redis 的压…...
斯坦福UE4 C++课学习补充 14:UMG-优化血量条
文章目录 一、优化执行效率二、简单脉冲动画 一、优化执行效率 绑定事件需要每一帧检查绑定对象是否有变化,势必造成CPU资源的浪费,因此优化执行效率的思路是:UI组件不再自行每帧查询血量,而是让血量自己在发生变化的同时通知UI进…...
在生信分析中大家需要特别注意的事情
在生信分析中大家需要特别注意的事情 标准的软件使用和数据分析流程 1. 先看我的b站教学视频 2. 先从我的百度网盘把演示数据集下载下来,先把要运行的模块的演示数据集先运行一遍 3. 前两步都做完了,演示数据集也运行成功了,并且知道了软件…...
Java工厂模式详解:方法工厂模式与抽象工厂模式
Java工厂模式详解:方法工厂模式与抽象工厂模式 一、引言 在Java开发中,设计模式是解决常见软件设计问题的一种有效方式。工厂模式作为创建型设计模式的一种,提供了灵活的对象创建机制,有助于降低代码的耦合度,提高系…...
springSecurity学习之springSecurity用户单设备登录
用户只能单设备登录 有时候在同一个系统中,只允许一个用户在一个设备登录。 之前的登陆者被顶掉 将最大会话数设置为1就可以保证用户只能同时在一个设备上登录 Override protected void configure(HttpSecurity http) throws Exception {http..anyRequest().aut…...
微信小程序实现聊天界面,发送功能
.wxml <scroll-view scroll-y"true" style"height: {{windowHeight}}px;"><view wx:for"{{chatList}}" wx:for-index"index" wx:for-item"item" style"padding-top:{{index0?30:0}}rpx"><!-- 左…...
【强化学习的数学原理】课程笔记--5(值函数近似,策略梯度方法)
目录 值函数近似一个例子TD 算法的值函数近似形式Sarsa, Q-learning 的值函数近似形式Deep Q-learningexperience replay 策略梯度方法(Policy Gradient)Policy Gradient 的目标函数目标函数 1目标函数 2两种目标函数的同一性 Policy Gradient 目标函数的…...
前端Long类型精度丢失:后端处理策略
文章目录 精度丢失的具体原因解决方法1. 使用 JsonSerialize 和 ToStringSerializer2. 使用 JsonFormat 注解3. 全局配置解决方案 结论 开发商城管理系统的品牌管理界面时,发现一个问题,接口返回品牌Id和页面展示的品牌Id不一致,如接口返回的…...
C++ | Leetcode C++题解之第300题最长递增子序列
题目: 题解: class Solution { public:int lengthOfLIS(vector<int>& nums) {int len 1, n (int)nums.size();if (n 0) {return 0;}vector<int> d(n 1, 0);d[len] nums[0];for (int i 1; i < n; i) {if (nums[i] > d[len])…...
springboo 整合 redis
springBoot 整合 redis starter启动依赖。—包含自动装配类—完成相应的装配功能。 引入依赖 <!--引入了redis整合springboot 的依赖--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis&…...
dpdk编译安装以及接收udp报文(基于ubuntu)
目录 1、编译 2、设置运行环境 3、使用dpdk接收udp报文 3.1、设置发送端arp信息 3.2、测试 3.3、代码 4、其他 1、编译 代码下载: DPDK 下载版本:DPDK 19.08.2 export RTE_SDK/root/dpdk-stable-19.08.2/ export RTE_TARGETx86_64-native-li…...
【计算机网络】OSPF单区域实验
一:实验目的 1:掌握在路由器上配置OSPF单区域。 2:学习OSPF协议的原理,及其网络拓扑结构改变后的变化。 二:实验仪器设备及软件 硬件:RCMS交换机、网线、内网网卡接口、Windows 2019操作系统的计算机等。…...
Java聚合快递小程序对接云洋系统程序app源码
一场物流效率的革命 引言:物流新时代的序章 在数字化浪潮席卷各行各业的今天,物流行业也迎来了前所未有的变革。为了进一步提升物流效率,优化用户体验,聚合快递系统与云洋系统小程序的对接成为了行业内外关注的焦点。这一创新…...
【React】详解组件通信:从基础到进阶的全面指南
文章目录 一、父组件向子组件传递数据1. 基本概念2. 示例代码3. 详解定义子组件 Son定义父组件 App导出父组件 App数据流props 的内容 二、子组件向父组件传递数据1. 基本概念2. 示例代码3. 详解引入React库和useState钩子定义子组件 Son定义父组件 App导出父组件 App数据流 三…...
【vluhub】zabbix漏洞
介绍: zabbix是对服务器资源状态例如、内存空间、CPU、程序运行状态进行检测、设置预警值、短信设置等功能等一款开源工具。配置不当存在未授权,SQL注入漏洞 弱口令 nameadmin&passwordzabbix nameguest&password POST /index.php HTTP/1.1 Host: 192.1…...
openGauss触发器详解
openGauss 是一款开源关系型数据库管理系统,广泛应用于企业级应用中。随着数据量的增长和业务逻辑的复杂化,数据库管理和操作的自动化需求越来越高。触发器(Triggers)作为数据库中重要的编程工具,能够极大地简化复杂操…...
抄作业-跟着《React通关秘籍》捣鼓React-playground-上集
文章目录 前言1. 搭建react 开发环境2、react hooks 知识3. 目标:跟着小册实现 react-playground3.1 整体布局初始化项目使用Alloment 来实现左右分屏的拖拉功能 3.2 代码编辑器Monaco Editor 3.3 实现了多文件的切换用 useContext 来共享数据。优化 tab的样式&…...
80后最后的书信 年代
当时11亿人口只有1.8万部固定电话 中国几千年来 鱼传尺素 雁寄鸿书 写信最后要写 亲啓 如有照片,封面要写内有照片,请勿折叠 信的开头应该是 见字如面,展信舒颜 如果拜托别人做事情,最后要写为盼 最后要写 某某草 书未尽…...
软考-软件设计师(4)-计算机网络与安全:OSI七层、子网划分、网络安全控制技术、网络安全协议、网络安全威胁、对称与非对称加密等高频考点
场景 软考-软件设计师-计算机网络与信息安全模块高频考点整理。 以下为高频考点、知识点汇总,不代表该模块所有知识点覆盖,请以官方教程提纲为准。 注: 博客:霸道流氓气质-CSDN博客 实现 知识点 OSI/RM七层模型 注意各层的主要功能,特别是表示层负责数据的加密、压…...
Unity横板动作游戏 -为什么我又开始学习Unity,而不是Godot。
Readme 最近开始学习Unity制作2D动作游戏,由于一些操作第一次接触,为了加深印象,准备写这样一篇同步教程的笔记。 之前也接触过Unity,用 Unity 制作过一个非常简单的小游戏 Flappy Bird,并且魔改成了泰拉瑞亚的版本。…...
什么是NIO
NIO(New Input/Output),也称为Java非阻塞IO,是从Java 1.4版本开始引入的一个新的IO API,旨在提供一种比传统的阻塞IO更高效、更灵活的IO操作方式。 一 NIO用法的详细介绍 NIO支持面向缓冲区的、基于通道的IO操作&…...
PHP switch 替代品 match
match 是 PHP 8 中引入的新特性。在 PHP 8 中,match 用作新的类型安全的替代 switch 语句。它提供了更清晰、更简洁的语法,同时还支持表达式作为条件,可以更轻松地处理复杂的条件逻辑。 在 match 表达式中,每个分支都是一个条件和…...
FastAPI(七十四)实战开发《在线课程学习系统》接口开发-- 删除留言
源码见:"fastapi_study_road-learning_system_online_courses: fastapi框架实战之--在线课程学习系统" 之前文章FastAPI(七十三)实战开发《在线课程学习系统》接口开发-- 回复留言,那么我们这次分享删除留言接口的开发…...
面试重点---快速排序
快排单趟 快速排序是我们面试中的重点,这个知识点也很抽象,需要我们很好的掌握,而且快速排序的代码也是非常重要,需要我们懂了还不行,必须要手撕代码,学的透彻。 在研究快速排序之前,我们首先…...
[MIT6.5840]MapReduce
MapReduce Lab 地址 https://pdos.csail.mit.edu/6.824/labs/lab-mr.html 论文地址 https://static.googleusercontent.com/media/research.google.com/zh-CN//archive/mapreduce-osdi04.pdf 工作原理 简单来讲,MapReduce是一种分布式框架,可以用来处理…...