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

用一个例子告诉你 怎样使用Spark中RDD的算子

目录

1. 前言

1.1 操作分类

1.2 语法知识

2. transformations

2.1 map

2.2  mapPartitions

2.3 flatMap

2.4 glom

2.5 groupBy

2.6 filter 

2.7 sample

2.8 distinct

2.9 coalesce

2.10 repartition

2.11 sortBy

2.12 partitionBy

2.13 reduceByKey

2.14 groupByKey

2.15 aggregateByKey

2.16 foldByKey

2.17 combineByKeyWithClassTag

2.18 combineByKey

2.19 sortByKey

2.20 cogroup

2.21 join、leftOuterJoin、rightOuterJoin、fullOuterJoin

2.22 intersection、union、subtract、zip

3. actions

3.1 reduce

3.2 collect

3.3  count

3.4 first

3.5 take

3.6  takeOrdered

3.7 aggregate

3.8 fold

3.9 countByKey

3.10  saveAsTextFile 、saveAsObjectFile 、 saveAsSequenceFile

3.11 foreach


1. 前言

我们可以将RDD想象成一张分布式的表,表中的数据以分区的形式分布在不同的计算节点上

对表操作称之为算子,可以用SQL的思想来理解这些操作

1.1 操作分类

在spark中,RDD支持两种类型的操作
        1.transformations(转换算子)
        功能:
                  从现有的RDD中通过某种转换规则,创建的新RDD
        特点:
                 所有的转换操作都是懒加载,并不会立即进行转换操作
                 只有当驱动程序需要计算结果时,才会触发转换行为

        2.actions(行动算子)
        功能:
                 将各个计算节点上的结果数据,返回给驱动程序(客户端)

通常,我们也会将RDD的操作称之为算子,也就是人们常说 转换算子、行动算子

 官方API链接:   https://spark.apache.org/docs/latest/api/scala/org/apache/spark/rdd/RDD.html


1.2 语法知识

        这块知识需要对scala基本语法有些了解,才会对API调用有更好的理解

        什么是Lambda表达式? 传送门

        什么是函数柯里化?传送门

        什么是隐式转换及隐式函数?传送门


2. transformations

2.1 map

功能:  返回一个新的RDD,对父RDD的每个元素按照f函数进行转换

可以看我之前写的例子 : 传送门

重点关注:

        分区内元素依次被指定Lambda表达式执行(串行),多个分区间并发执行(并行)

        如果指定的Lambda表达式中存在消耗时间的逻辑(如 数据库连接、IO等)

        请选择使用mapPartitions


2.2  mapPartitions

功能: 返回一个新的RDD,对父RDD每个分区按照f函数进行转换

可以看我之前写的例子 : 传送门

重点关注: 1.map和mapPartitions的区别

                2.mapPartitions的使用风险和使用场景

                3.Lambda表达式每次会处理整个分区的数,小心内存溢出哦😯


2.3 flatMap

功能:  返回一个新的RDD,将父RDD中每个元素转换成集合,再将集合打散

可以看我之前写的例子 : 传送门


2.4 glom

功能: 返回一个新的RDD,将父RDD每个分区中的所有元素封装到数组中去

可以看我之前写的例子 : 传送门

重点关注:

         1. 用于将父RDD中每个分区的数据打包成数组

         2. 不会触发shuffle操作哦        


2.5 groupBy

功能: 返回一个新的RDD,对父RDD所有元素按照f函数的结果进行分组

可以看我之前写的例子 : 传送门

实现1: 使用默认分区器,分区数=父RDD分区数

实现2: 指定分区数,默认使用Hash分区器

 实现3: 使用指定分区器

 重点关注:  

             1.这个操作会触发shuffle操作,当数据分布不均时,可能会造成某个分区数据量过大
                而导致内存溢出哦😯,也就是常说的数据倾斜         

             2.如果分组的目的是为了做 聚合操作,建议使用 reduceByKey、aggregateByKey 
                效率会高很多(这些算子,会map端先做一次聚合操作,来减少IO的数据量) 


2.6 filter 

功能: 返回一个新的RDD,对父RDD的所有元素按照 f(x) = true 进行过滤

可以看我之前写的例子 : 传送门


2.7 sample

功能: 返回一个新的RDD,对父RDD做抽样查询

可以看我之前写的例子 : 传送门


2.8 distinct

功能: 返回一个新的RDD,对父RDD元素去重

可以看我之前写的例子 : 传送门

实现1: 不指定分区个数

实现2: 指定分区个数

重点关注:  

              1. 会触发shuffle操作,会先在map端对数据去重后,再在reduce端去重


2.9 coalesce

功能: 返回一个新的RDD,增加或减少父RDD的分区个数(合并分区时,可以选择不shuffle)

可以看我之前写的例子 : 传送门

 重点关注:

        shuffle = true时,会触发shuffle操作,小心数据倾斜哦😱

        合并分区时,建议使用 coalesce且shuffle=false   


2.10 repartition

功能: 返回一个新的RDD,增加或减少父RDD的分区个数(必触发shuffle)

可以看我之前写的例子 : 传送门 

重点关注:

        一定会触发shuffle操作,如果是减少分区,建议使用  coalesce


2.11 sortBy

功能: 返回一个新的RDD,对父RDD根据f函数的结果排序

可以看我之前写的例子 : 传送门

 重点关注:

        会触发shuflle操作,小心数据倾斜哦😱


2.12 partitionBy

功能:  返回一个新的RDD,按照指定分区器对父RDD重新分区

可以看我之前写的例子 :  传送门

注意事项:

        1.当父RDD数据分布不均时,可以使用此方法将数据打散


2.13 reduceByKey

功能: 返回一个新的RDD,根据指定的聚合规则对父RDD  按照key做聚合

         分区内(map端)、分区间(reduce端)聚合逻辑相同,且没有初始值参与聚合

可以看我之前写的例子 : 传送门

实现1:

实现2:

 实现3:使用默认分区器,分区数和父RDD相同

重点关注:  

        1. 这个方法 会先在每个map端本地做一次聚合,合并完后再发送到reduce端聚合

        2. 此方法会触发shuffle操作,小心数据倾斜哦😟!!!


 2.14 groupByKey

功能: 返回一个新的RDD,按照key对父RDD做分组

可以看我之前写的例子 : 传送门

实现1:

 实现2:

 重点关注:  

             1. 目前实现方式,会先将每个key的所有键值对读取到内存中,如果一个key的值过多时
                 就会导致OutOfMemoryError错误,使用前一定要评估数据量和内存资源

             2.这个操作会触发shuffle操作,当数据分布不均时,可能会造成某个分区数据量过大
                而导致内存溢出哦😯,也就是常说的数据倾斜         

             3.如果分组的目的是为了做 聚合操作,那么可以使用 reduceByKey、aggregateByKey 
                效率会高很多(这些算子,会map端先做一次聚合操作,来减少IO的数据量) 


2.15 aggregateByKey

功能: 返回一个新的RDD,根据指定的聚合规则 对父RDD 按照key做聚合

         分区内(map端)、分区间(reduce端)聚合逻辑可以不相同,且有初始值参与聚合

可以看我之前写的例子 :  传送门

方式1:

 方式2:

方式3:

重要关注:

           1. zeroValue值 会参与分区聚合计算和分区间聚合计算

           2. 此方法会触发shuffle操作,小心数据倾斜哦😟!!!


2.16 foldByKey

功能:  返回一个新的RDD,根据指定的聚合规则 对父RDD 按照key做聚合

         分区内(map端)、分区间(reduce端)聚合逻辑相同,且有初始值参与聚合

可以看我之前写的例子 :  传送门 

方式1:

方式2:

 方式3:

重要关注:

           1. zeroValue值 会参与分区聚合计算和分区间聚合计算

           2. 此方法会触发shuffle操作,小心数据倾斜哦😟!!!


2.17 combineByKeyWithClassTag

功能:  返回一个新的RDD,根据指定的聚合规则 对父RDD 按照key做聚合

         分区内(map端)、分区间(reduce端)聚合逻辑可以不相同,且有初始值参与聚合

         并且可以转换value的数据类型

可以看我之前写的例子 :  传送门

实现1:实现2: 实现3:

重点关注:

          1. 这是RDD聚合操作中最通用的方法,其他聚合函数都是对它的封装

          2. RDD分区数量和数据分布直接会影响聚合操作的效率,使用时注意数据分布哦


2.18 combineByKey

功能:  返回一个新的RDD,根据指定的聚合规则 对父RDD 按照key做聚合

         分区内(map端)、分区间(reduce端)聚合逻辑可以不相同,没有初始值参与聚合

         并且可以转换value的数据类型

可以看我之前写的例子 :  传送门

方式1:方式2:重点关注:

        1. 查看源码,是对combineByKeyWithClassTag的封装


2.19 sortByKey

功能:  返回一个新的RDD,元素值为  父RDD 根据key排序的结果

可以看我之前写的例子 : 传送门

重点关注:

        1. key的数据类型 必须实现 Ordered 接口(特质)

        2. key类型为tuple时,无法使用该方法排序

        3. 存在shuffle过程,小心数据倾斜哦


2.20 cogroup

功能:  返回一个新的RDD,元素值为 多个RDD下相同key下 各自value值的迭代器

可以看我之前写的例子 : 传送门

实现1:实现2:

 实现3:

注意事项:

        1. 多个RDD关联最通用的方法

        2. 会触发shuffle操作,小心数据倾斜哦


2.21 join、leftOuterJoin、rightOuterJoin、fullOuterJoin

功能:  返回一个新的RDD,元素值为 多个RDD下相同key下 的各自value值

可以看我之前写的例子 :  传送门 

join:leftOuterJoin:rightOuterJoin:fullOuterJoin:重点关注:

        1. 发下没有,都是通过封装 cogroup + flatMapValues 来实现的

        2. 会触发shuffle操作,小心数据倾斜哦


2.22 intersection、union、subtract、zip

功能:  返回一个新的RDD,元素值为 两个RDD求交集、并集、差集 的结果

可以看我之前写的例子 :  传送门

intersection:返回两个RDD的交集,结果将不包含任何重复元素  (内部会触发shuffle过程)

union:返回多个RDD的并集,结果会有重复元素 (内部不会触发shuffle过程)

subtract:返回两个RDD的差集 (内部会触发shuffle过程)

zip:返回两个RDD按元素顺序对应的二元组 (内部不会触发shuffle过程)


3. actions

3.1 reduce

功能: 根据指定的计算规则,对RDD所有的元素依次做运算,并返回计算结果给驱动程序(Driver)

可以看我之前写的例子 : 传送门

注意事项:

        1.先在每个分区内做聚合操作(Map端),再对各个分区的结果做聚合操作

           如果操作不满足结合律和交换律时(如减法、除法), 当分区个数不同时,计算结果也会不同


3.2 collect

功能:返回给Driver端一个数组,数组内容为RDD所有的元素

可以看我之前写的例子 :  传送门

注意事项:

        1. 当RDD元素过多时,小心Driver端内存溢出哦


3.3  count

功能:返回RDD元素个数给Driver端

可以看我之前写的例子 : 传送门


3.4 first

功能:返回RDD第一个元素的值 给Driver端

可以看我之前写的例子 : 传送门


3.5 take

功能: 返回给Driver端一个数组,数组内容为RDD的前n项元素

可以看我之前写的例子 : 传送门

注意事项:

        1. 当返回元素过多时,小心Driver端内存溢出哦

        2. 如果在Nothing或Null的RDD上调用此方法将引发异常 


3.6  takeOrdered

功能: 返回给Driver端一个数组,数组内容为RDD排序后的前n项元素

可以看我之前写的例子 : 传送门

 注意事项:

        1. 当返回元素过多时,小心Driver端内存溢出哦


3.7 aggregate

功能:对RDD做聚合操作,并将聚合的结果返回给Driver端

可以看我之前写的例子 : 传送门

注意事项:

        1.zeroValue会参与分区内聚合运算和分区间聚合运算

           通常会将它设置成一个中立元素(列表连接Nil 计数时为0)


3.8 fold

功能:对RDD做聚合操作,并将聚合的结果返回给Driver端

可以看我之前写的例子 : 传送门


3.9 countByKey

 功能:计算RDD中每个key下的value的个数,并将结果返回给Driver端

可以看我之前写的例子 : 传送门

注意事项:

        1. 当返回结果集过大时,小心Driver端内存溢出哦


3.10  saveAsTextFile 、saveAsObjectFile 、 saveAsSequenceFile

可以看我之前写的例子:传送门

saveAsTextFile:

功能:将RDD以文本文件的格式保存到指定路径

实现1:

实现2:


saveAsObjectFile

功能:将RDD以序列化对象的格式保存到指定路径


 saveAsSequenceFile 

功能:将RDD以Hadoop SequenceFile的格式保存到指定路径


3.11 foreach

功能:将指定的Lambda表达式,应用在RDD的每个元素上

可以看我之前写的例子:传送门

重点关注:

        1. 分区内按元素顺序依次执行Lambda表达式,分区间是并行的

相关文章:

用一个例子告诉你 怎样使用Spark中RDD的算子

目录 1. 前言 1.1 操作分类 1.2 语法知识 2. transformations 2.1 map 2.2 mapPartitions 2.3 flatMap 2.4 glom 2.5 groupBy 2.6 filter 2.7 sample 2.8 distinct 2.9 coalesce 2.10 repartition 2.11 sortBy 2.12 partitionBy 2.13 reduceByKey 2.14 gro…...

什么是跨域? 出现原因及解决方法

目录一、什么是跨域二、为什么有跨域问题?三、解决跨域问题的方案1.Jsonp2.nginx3.CORS3.1 什么是cors3.2 原理四、GateWay网关中实现跨域步骤一、什么是跨域 跨域:浏览器对于javascript的同源策略的限制 。 同源政策的目的,是为了保证用户…...

低代码系统能够解决哪些痛点?

低代码系统能够解决哪些痛点?如果用4句话去归纳,低代码开发可以解决以下问题—— 为企业提供更高的灵活性,用户可以突破代码的限制自主开发业务应用;通过减少对专业软件开发人员的依赖,公司可以快速响应市场上的新业务…...

华为OD机试题,用 Java 解【两数之和绝对值最小】问题

最近更新的博客 华为OD机试题,用 Java 解【停车场车辆统计】问题华为OD机试题,用 Java 解【字符串变换最小字符串】问题华为OD机试题,用 Java 解【计算最大乘积】问题华为OD机试题,用 Java 解【DNA 序列】问题华为OD机试 - 组成最大数(Java) | 机试题算法思路 【2023】使…...

AcWing算法提高课-3.1.1热浪

宣传一下算法提高课整理 <— CSDN个人主页&#xff1a;更好的阅读体验 <— 题目传送门点这里 题目描述 德克萨斯纯朴的民众们这个夏天正在遭受巨大的热浪&#xff01;&#xff01;&#xff01; 他们的德克萨斯长角牛吃起来不错&#xff0c;可是它们并不是很擅长生产富…...

华为OD机试题【最差产品奖】用 C++ 编码,速通 (2023.Q1)

最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为od机试,独家整理 已参加机试人员的实战技巧文章目录 最近更新的博客使用说明最差产…...

NFT市场大战:Blur市场地位可持续吗?

在战胜无数虚张声势的挑战者之后&#xff0c;OpenSea终于迎来了一个实力雄厚的竞争对手&#xff0c;已威胁到它的市场主导地位。opensea是什么&#xff1f;参考《NFT&#xff0c;区块链的产物之一&#xff0c;了解NFT交易平台Opensea》 继成功的空投之后&#xff0c;Blur并没有…...

初识CSS

1.CSS语法形式CSS基本语法规则就是:选择器若干属性声明由选择器选择一个元素,其中的属性声明就作用于该元素.比如:<body><p>这是一个段落</p><!-- style可以放在代码的任意地方 --><style>p{/* 将字体颜色设置为红色 */color: red;}</style&g…...

kubernetes(k8s)知识总结(第3期)

1. PV 与 PVC PV 是持久卷&#xff08;Persistent Volume&#xff09;的首字母缩写。通常情况下&#xff0c;可以事先在 k8s 集群创建 PV 对象&#xff1a; apiVersion: v1 kind: PersistentVolume metadata:name: nfs spec:storageClassName: manualcapacity:storage: 1Giac…...

浅谈跨境电商运行模式

近些年&#xff0c;由于疫情的原因和人们的消费习惯的改变&#xff0c;线下销售越来越不占优势&#xff0c;电商行业由于这几年的飞速发展&#xff0c;成功地吸引到我国的民众&#xff0c;拼多多、淘宝、京东、天猫等各种各样的国内电商平台涌现&#xff0c;依靠着产品质量好、…...

Memcached

什么是MemcachedMemcached 是一个开源免费的高性能的分布式内存对象缓存系统、就是一个软件Memcached的作用缓存数据提高动态网站的速度Memcached的安装//方法一yum installmemcached//方法二1.安装libevent (memcached依赖包)tar -zvxflibevent-release-1.4.15-stable.tar.gzc…...

Unity UGUI 拖拽组件

效果展示 使用方式 拖到图片上即可用 父节点会约束它的活动范围哦~ 父节点会约束它的活动范围哦~ 父节点会约束它的活动范围哦~ 源码 using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.EventSystems;/// <summary> /…...

面试总结——react生命周期

react生命周期总结 生命周期主要分为以下几个阶段&#xff1a; Mounting:创建虚拟DOM&#xff0c;渲染UI(初始化)Updating&#xff1a;更新虚拟DOM&#xff0c;重新渲染UI&#xff1b;(更新)UnMounting&#xff1a;删除虚拟DOM&#xff0c;移除UI&#xff1b;(销毁) 生命周期…...

初探推荐系统-01

文章目录一、什么是推荐系统是什么为什么长尾理论怎么做二、相似度算法杰卡德相似系数余弦相似度三、基于内容的推荐算法如何获取到用户喜欢的物品如何确定物品的特征四、推荐算法实验方法评测指标推荐效果实验方法1、离线实验2、用户调查3、在线实验评测指标1、预测准确度评分…...

html实现浪漫的爱情日记(附源码)

文章目录1.设计来源1.1 主界面1.2 遇见1.3 相熟1.4 相知1.5 相念2.效果和源码2.1 动态效果2.2 源代码2.3 代码结构源码下载更多爱情表白源码作者&#xff1a;xcLeigh 文章地址&#xff1a;https://blog.csdn.net/weixin_43151418/article/details/129264757 html实现浪漫的爱情…...

detectron2容器环境安装问题(1)

1为避免后面出现需求python版本低于3.7的情况ERROR: Package detectron2 requires a different Python: 3.6.9 not in >3.7可以第一步就使用 nvidia/cuda:11.1.1-cudnn8-devel-ubuntu20.04镜像2如果使用了18.04的镜像nvidia/cuda:11.1.1-cudnn8-devel-ubuntu18.04可以使用我…...

JAVA线程池原理详解二

JAVA线程池原理详解二 一. Executor框架 Eexecutor作为灵活且强大的异步执行框架&#xff0c;其支持多种不同类型的任务执行策略&#xff0c;提供了一种标准的方法将任务的提交过程和执行过程解耦开发&#xff0c;基于生产者-消费者模式&#xff0c;其提交任务的线程相当于生…...

Java 常用 API

文章目录一、Math二、System三、Object1. toString() 方法2. equals() 方法四、Arrays1. 冒泡排序2. Arrays 常用方法五、基本类型包装类1. Integer2. int 和 String 相互转换3. 字符串中数据排序4. 自动装箱和拆箱六、日期类1. Date2. SimpleDateFormat3. Calendar4. 二月天一…...

记一次分布式环境下TOKEN实现用户登录

背景&#xff1a; ​ 以前的单体项目&#xff0c;使用的是session来保存用户登录状态&#xff0c;控制用户的登录过期时间等信息&#xff0c;但是这个session是只保存在该服务器的这个系统内存中。系统只有一个服务就没关系&#xff0c;但是如果是分布式的服务&#xff0c;每个…...

用cpolar发布本地的论坛网站 1

网页论坛向来是个很神奇的地方&#xff0c;曾经的天涯论坛和各种BBS&#xff0c;大家聚在在一起讨论某个问题&#xff0c;也能通过论坛发布想法&#xff0c;各种思维碰撞在一起&#xff0c;发生很多有趣的故事&#xff0c;也产生了很多流传一时的流行语录。当然&#xff0c;如果…...

CSS的4种引入方式

CSS的4种引入方式 目录CSS的4种引入方式一、内嵌式&#xff1a;CSS写在style标签中二、外联式&#xff1a;CSS写在一个单独的.css文件中三、行内式&#xff1a;CSS写在标签的style属性中四、导入外部样式五、css引用的优先级六、link和import的区别一、内嵌式&#xff1a;CSS写…...

Shell高级——Linux中的文件描述符(本质是数组的下标)

以下内容源于C语言中文网的学习与整理&#xff0c;非原创&#xff0c;如有侵权请告知删除。 前言 Linux中一切接文件&#xff0c;比如 C 源文件、视频文件、Shell脚本、可执行文件等&#xff0c;就连键盘、显示器、鼠标等硬件设备也都是文件。 一个 Linux 进程可以打开成百上…...

Nvidia jetson nano硬件架构

资料来源 官方文档中心 https://developer.nvidia.com/embedded/downloads -> 选jetson -> Jetson Nano Product Design Guide //产品设计指导(入口) //-> 1.1 References 列出了相关的文档 -> Jetson Nano Developer Kit Carrier Board Specification //板子标注…...

ffmpeg多路同时推流

一、ffmpeg常见使用方法1.1利用FFMPEG命令进行文件分割1.2转换格式1.3推流配置方法一&#xff1a;ngnix&#xff08;不推荐&#xff0c;推流不好使&#xff09;方法二&#xff1a;srs&#xff08;强烈推荐&#xff09;1.4查看nginx启动是否成功二、ffmpeg推流——>ngnix单路…...

一次性搞定 `SHOW SLAVE STATUS` 的解读

一次性搞定 SHOW SLAVE STATUS 的解读 解析日志文件的位置 诚然, GTID(全局事务标识符)已经在 MySQL 5.6中得到支持, 此外,还可以通过 Tungsten replicator 软件来实现(2009年以后一直有谷歌在维护,不是吗?)。 但有一部分人还在使用MySQL 5.5的标准副本方式, 那么这些二进制日…...

【代码随想录训练营】【Day25】第七章|回溯算法 |216.组合总和III|17.电话号码的字母组合

组合总和III 题目详细&#xff1a;LeetCode.216 做过上一题组合后&#xff0c;再来写这道题就显得得心应手了&#xff0c;通过理解回溯算法的模版&#xff0c;也总结出了算法中的一些特点&#xff1a; 回溯算法与递归算法类似&#xff0c;同样需要参数、结束条件和主体逻辑回…...

docker使用

https://blog.csdn.net/u012563853/article/details/125295985http://www.ppmy.cn/news/11249.html启动 docker服务并设置开机自动启动dockersudo systemctl start docker sudo systemctl enable dockerdocker 常见启动失败问题:https://blog.csdn.net/zhulianseu/article/deta…...

手把手docker registry配置登录名/密码

我们的Docker私有仓库Registry服务只有加了认证机制之后我们的Registry服务才会更加的安全可靠。赶快跟随以下步骤来增加认证机制吧。 创建docker registry工作目录 mkdir -p /data/docker.registry 创建将保存凭据的文件夹 mkdir -p /data/docker.registry/etc/registry/auth…...

一步打通多渠道服务场景 中电金信源启移动开发平台MADP功能“上新”

日前&#xff0c;中电金信源启移动开发平台MADP功能迭代升级&#xff0c;“上新”源启小程序开发平台。定位“为金融业定制”的移动PaaS平台&#xff0c;源启小程序开发平台为银行、互联网金融、保险、证券客户提供一站式小程序的开发、运营、营销全生命周期管理技术支撑&#…...

Kubernetes06:Controller (Deployment无状态应用)

Kubernetes06:Controller 1、什么是controller 管理和运行容器的对象&#xff0c;是一个物理概念 在集群上管理和运行容器的对象 2、Pod和Controller之间的关系 Pod是通过controller来实现应用的运维 比如伸缩、滚动升级等等操作Pod和Controller之间通过 label 标签建立关系…...

低代码开发平台选型必看指南

低代码开发是近年来逐渐兴起的一种新型软件开发方式。它通过封装常见的软件开发流程和代码&#xff0c;使得非专业的开发者也能够轻松创建复杂的应用程序。这种开发方式已经受到了许多企业的青睐&#xff0c;成为提高生产效率、降低开发成本的一种有效途径。 低代码开发的核心…...

OVN:ovn20.03.1/ovs2.13.0编译rpm过程

操作系统openeuler22.0&#xff0c;x86架构分别下载ovn和ovs的源码https://github.com/openvswitch/ovs/tree/v2.13.0https://github.com/ovn-org/ovn/tree/v20.03.1安装必要工具&#xff1a;yum install -y unzip tar make autoconf automake libtool rpm-build gcc libuuid-d…...

Shell管道

一、管道是什么 英文是pipe。 把一个命令的标准输出作为下一个命令的标准输入&#xff0c;以这种方式连接的两个或者多个命令就形成了管道 使用竖线|连接多个命令&#xff0c;称为管道符。 语法格式如下&#xff1a; command1 | command2 [ | commandN... ] command1的标准…...

Zynq UltraScale系列使用MIPI CSI-2 RX Subsystem 解码MIPI视频PD输出 提供2套工程源码和技术支持

目录1、前言2、设计思路和架构3、vivado工程详解4、上板调试验证5、福利&#xff1a;工程代码的获取1、前言 本设计采用OV5640摄像头MIPI模式作为输入&#xff0c;分辨率为1280x72060Hz&#xff0c;MIPI解码方案采用Xilinx官方提供的MIPI CSI-2 RX Subsystem IP解码MIPI视频&a…...

C++:详解C++11 线程休眠函数

休眠函数简介1: 让线程休眠一段时间1.1&#xff1a;std::chrono 的时钟 clock简介 C11 之前并未提供专门的休眠函数&#xff0c;C语言的 sleep、usleep函数其实是系统提供的函数&#xff0c;不同的系统函数的功能还要些差异。 在Windows系统中&#xff0c;sleep的参数是毫秒 …...

TryHackMe-The Great Escape(Docker)

The Great Escape 我们的开发人员创建了一个很棒的新网站。你能冲出沙盒吗&#xff1f; 端口扫描 循例 nmap Web信息收集 robots.txt: /exif-util是文件上传点&#xff0c;但是绕过之后貌似没啥用 在robots.txt当中披露了可能存在.bak.txt&#xff0c;现在我们已知的文件就是…...

这么强才给我28k,我头都不回,转身拿下40k~

时间真的过得很快&#xff0c;眨眼就从校园刚出来的帅气小伙变成了油腻大叔&#xff0c;给各位刚入道的测试朋友一点小建议&#xff0c;希望你们直通罗马吧&#xff01; 如何选择自己合适的方向 关于选择测试管理&#xff1a; 第一&#xff0c;你一定不会是一个喜欢技术&…...

【Python学习笔记】第二十一节 Python Lambda 函数

Python 提供了非常多的库和内置函数。有不同的方法可以执行相同的任务&#xff0c;而在 Python 中&#xff0c;有个万能之王函数&#xff1a;lambda 函数&#xff0c;它以不同的方式在任何地方使用。一、Lambda 函数简介在 Python 中&#xff0c;函数可以接受一个或多个位置参数…...

Nginx学习整理

Nginx学习第一章 Nginx概述1.1、Nginx概述1.2、Nginx官网1.3、Nginx用处第二章 Nginx单实例安装2.1、环境说明2.2、安装依赖2.3、Nginx下载2.4、Nginx解压2.5、Nginx安装2.6、Nginx命令2.7、开放防火墙2.8、启动后效果第三章 Nginx正向代理、反向代理3.1、概述3.2、反向代理配置…...

阿里面试之Hr面,这个套路把我坑惨了......

作为技术类的测试工程师面试&#xff0c;往往要经过多次面试才能拿到心仪的offer&#xff0c;这里面有技术一面、二面…&#xff0c;甚至总监面等&#xff0c;还有一个必不可少的就是HR面&#xff0c;一般HR会出现在你面试的最前面和最后面&#xff0c;前面是了解你的基本情况&…...

域基础和基本环境搭建

1.1 名词解释 域和工作组的区别&#xff1a; 工作组中所有的计算机都是对等的&#xff0c;也就是没有服务器和客户机的之分&#xff0c;所以工作组并不存在真正的集中管理作用&#xff1b;域是一个有安全边界的计算机集合&#xff0c;安全边界指的是一个域中的用户无法访问到另…...

Java Map集合体系(HashMap、LinkedHashMap、TreeMap、集合嵌套)

目录Map集合体系一、Map集合的概述二、Map集合体系特点三、Map集合常用API四、Map集合的遍历4.1 Map集合的遍历方式一&#xff1a;键找值4.2 Map集合的遍历方式二&#xff1a;键值对4.3 Map集合的遍历方式三&#xff1a;lambda表达式五、Map集合案例-统计投票人数六、Map集合的…...

使用邮箱验证实现登录功能(发送邮件,redis)

目录 概述 前端搭建 后端搭建 生成验证码-存入redis&#xff08;主要过程代码&#xff09; 发送邮件&#xff08;主要过程代码&#xff09; 登录验证-取出redis中数据进行验证&#xff08;主要代码&#xff09; 完整代码一-LoginController 完整代码二-LoginService 完…...

【Linux】网卡的7种bond模式

网卡的7种bond模式 一、bond模式 Mode0(balance-rr) 表示负载分担round-robin&#xff0c;和交换机的聚合强制不协商的方式配合 Mode1(active-backup) 表示主备模式&#xff0c;只有一块网卡是active,另外一块是备的standby&#xff0c;这时如果交换机配的是捆绑&#xff0c…...

AQS抽象队列同步器

aqs 抽象队列同步器&#xff0c;内部存储了一个valitail修饰的status 和内部类node &#xff0c;来实现对共享变量并发同步队列机制,以reentrantLock为例&#xff0c;lock底层实际上调用的是sync的lock&#xff0c;会调用cas对status的状态进行修改&#xff0c;来确定是否获得锁…...

springBoot对REST支持源码解析

一、在配置类中&#xff1a; AutoConfiguration(after { DispatcherServletAutoConfiguration.class, TaskExecutionAutoConfiguration.class,ValidationAutoConfiguration.class }) ConditionalOnWebApplication(type Type.SERVLET) ConditionalOnClass({ Servlet.class, D…...

6 集成学习及Python实现

1 主要思想 集成学习: 三个臭裨将, 顶个诸葛亮 Bagging: 数据随机重抽样, 并行构建分类器, 投票&#xff1b;Boosting: 关注被错分的样本, 串行构建分类器, 加权投票。 2 理论 AdaBoost (Adaptive Boosting)示意图1 错误率: εEN\varepsilon \frac{E}{N}εNE​ 其中NNN为…...

如何编程实现从多数据库操作数据

对于数据量很大的复杂系统&#xff0c;有时候会采用分库或者分表的减轻单台数据库服务器压力&#xff0c;截止目前有一些工具直接支持读写分离等&#xff0c;例如ShardingSphere&#xff0c;如果不采用工具框架&#xff0c;从编码出发&#xff0c;如何实现从多个数据库读写数据…...

LeetCode 147. 对链表进行插入排序 | C/C++版

LeetCode 147. 对链表进行插入排序 | C语言版LeetCode 147. 对链表进行插入排序题目描述解题思路思路一&#xff1a;使用栈代码实现运行结果参考文章&#xff1a;思路二&#xff1a;减少遍历节点数代码实现运行结果参考文章&#xff1a;[]()LeetCode 147. 对链表进行插入排序 …...

【QT进阶】第五章 QT绘图之自定义控件--仪表盘绘制

❤️作者主页:凉开水白菜 ❤️作者简介:共同学习,互相监督,热于分享,多加讨论,一起进步! ❤️专栏目录:【零基础学QT】文章导航篇 ❤️专栏资料:https://pan.baidu.com/s/192A28BTIYFHmixRcQwmaHw 提取码:qtqt ❤️点赞 👍 收藏 ⭐再看,养成习惯 订阅的粉丝可通过…...