Spark -orc internal

spark 基本概念介绍

RDD

直观上,RDD可理解为下图所示结构,即RDD包含多个Partition(分区),每个Partition代表一部分数据并位于一个计算节点

在这里插入图片描述

RDD本质上是Spark中的一个抽象类

RDD包含以下成员方法或属性:

1、compute方法

提供在计算过程中Partition元素的获取与计算方式

2、partition的列表

每一个partition代表一个并行的最小划分单元;

3、dependencies列表

描述RDD依赖哪些父RDD生成,即RDD的血缘关系;

4、partition的位置列表

定义如何最快速的获取partition的数据,加快计算,这个是可选的,可作为本地化计算的优化选项;

5、partitioner方法

定义如何对数据进行分区

前2个函数是所有RDD必须的,后三个可选,所有子RDD(HadoopRDD、MapPartitionRDD、JdbcRDD等)都要继承并实现其中的方法 。

RDD partition

由于RDD的数据量很大,因此为了计算方便,需要将RDD进行切分并存储在各个节点的分区当中,从而当我们对RDD进行各种计算操作时,实际上是对每个分区中的数据进行并行的操作

也就是一份待处理的原始数据会被按照相应的逻辑切分成多分,每份数据对应RDD的一个Partition,partition的数量决定了task的数量,影响程序的并行度

注意,如果使用hive table,此处RDD 的partition不是 hive table 中表的分区,表的不同分区以不同目录来分开存储,要注意区分。

RDD 算子

RDD算子分类,大致可以分为两类,即:

Transformation:转换算子,这类转换并不触发提交作业,完成作业中间过程处理。

常见的 Transformation算子 ,map,flatmap,reducebykey等

2. Action:行动算子,这类算子会触发SparkContext提交Job作业。

常见的 Action算子,collect,saveAsTextFile,count等

为了方便记忆,可以这么理解,action算子一般是在RDD上计算出来一个结果,把结果返回给driver program或保存在文件系统,返回结果非RDD类型,Transformation一般是传入函数对rdd进行操作,返回也是RDD。

RDD 依赖

RDD 和它依赖的父RDD 的关系有两种不同的类型, 即窄依赖( narrowdependency)和宽依赖(wide dependency)。

在这里插入图片描述

窄依赖是指每个父RDD的一个Partition最多被子RDD的一个Partition所使用,例如map、filter、union等操作都会产生窄依赖;

宽依赖是指一个父RDD的Partition会被多个子RDD的Partition所使用,例如groupByKey、reduceByKey、sortByKey等操作都会产生宽依赖;

需要特别说明的是对join操作有两种情况:如果两个RDD在进行join操作时,一个RDD的partition仅仅和另一个RDD中已知个数的Partition进行join,那么这种类型的join操作就是窄依赖,例如图1中左半部分的join操作(join with inputs co-partitioned);其它情况的join操作就是宽依赖,例如图1中右半部分的join操作(join with inputs not co-partitioned),由于是需要父RDD的所有partition进行join的转换,这就涉及到了shuffle,因此这种类型的join操作也是宽依赖。

总结:在这里我们是从父RDD的partition被使用的个数来定义窄依赖和宽依赖,因此可以用一句话概括下:如果父RDD的一个Partition被子RDD的一个Partition所使用就是窄依赖,否则的话就是宽依赖。因为是确定的partition数量的依赖关系,所以RDD之间的依赖关系就是窄依赖;由此我们可以得出一个推论:即窄依赖不仅包含一对一的窄依赖,还包含一对固定个数的窄依赖。

一对固定个数的窄依赖的理解:即子RDD的partition对父RDD依赖的Partition的数量不会随着RDD数据规模的改变而改变;换句话说,无论是有100T的数据量还是1P的数据量,在窄依赖中,子RDD所依赖的父RDD的partition的个数是确定的,而宽依赖是shuffle级别的,数据量越大,那么子RDD所依赖的父RDD的个数就越多,从而子RDD所依赖的父RDD的partition的个数也会变得越来越多。

Application

Term Meaning
Application 用户编写的Spark应用程序,包括一个Driver和多个executors
Application jar 包含用户程序的Jar包
Driver Program 运行main()函数并创建SparkContext进程
Cluster manager 在集群上获取资源的外部服务,如standalone manager,yarn,Mesos
deploy mode 部署模式,区别在于driver process运行的位置
worker node 集群中可以运行程序代码的节点(机器)
Executor 运行在worker node上执行具体的计算任务,存储数据的进程
Task 被分配到一个Executor上的计算单元
Job 由多个任务组成的并行计算阶段,因RDD的Action产生
Stage 每个Job被分为小的计算任务组,每组称为一个stage
DAGScheduler 根据Job构建基于Stage的DAG,并提交Stage给TaskScheduler
TaskScheduler 将TaskSet提交给worker运行,每个executor运行什么task在此分配

​ 一个Spark程序可以被划分为一个或多个Job,划分的依据是RDD的Action算子,每遇到一个RDD的Action操作就生成一个新的Job, 每个spark Job在具体执行过程中,将其划分为一个或多个stage,划分的依据是RDD间的Dependency关系,当遇到Wide Dependency时因需要进行shuffle操作, 故以此为界划分不同的Stage 。

​ Stage是由Task组组成的并行计算,因此每个stage中可能存在多个Task,这些Task执行相同的程序逻辑,只是它们操作的数据不同。一般RDD
的一个Partition对应一个Task, Partition的数目可以在创建RDD时指定,也可以通过reparation和coalesce等算子重新进行划分

将上面的概念串联起来,可以得到下面的运行层次图:

spark sql --orc

spark sql中的RDD

Spark SQL 最终将SQL 语句经过逻辑算子树转换成物理算子树。

在物理算子树中,叶子类型的SparkPlan 节点负责从无到有的创建RDD ,每个非叶子类型的SparkPlan 节点等价于在RDD 上进行一次Transformation ,即通过调用execute()函数转换成新的RDD ,最终执行collect()操作触发计算,返回结果给用户。

重点分析一下叶子节点:

在Spark SQL 中,LeafExecNode 类型的SparkPlan 负责对初始RDD 的创建。

HiveTableScanExec 会根据Hive数据表存储的HDFS 信息直接生成HadoopRDD;FileSourceScanExec 根据数据表所在的源文件生成FileScanRDD ,在2.3后的spark sql中,使用的就是这种方式从orc文件创建RDD。

spark sql orc 读取

spark sql 中读取orc的流程如下图

在这里插入图片描述

下面分析下图中标橘黄色的部分,inputsplit和Vectorized 读取。

spark sql orc inputsplit 源码分析

 /*** Create an RDD for non-bucketed reads.* The bucketed variant of this function is [[createBucketedReadRDD]].** @param readFile a function to read each (part of a) file.* @param selectedPartitions Hive-style partition that are part of the read.* @param fsRelation [[HadoopFsRelation]] associated with the read.*/private def createNonBucketedReadRDD(readFile: (PartitionedFile) => Iterator[InternalRow],selectedPartitions: Array[PartitionDirectory],fsRelation: HadoopFsRelation): RDD[InternalRow] = {// 配置项,默认128Mval defaultMaxSplitBytes =fsRelation.sparkSession.sessionState.conf.filesMaxPartitionBytes// 配置项,默认4Mval openCostInBytes = fsRelation.sparkSession.sessionState.conf.filesOpenCostInBytes// 参数,根据不同场景自动进行选择val defaultParallelism = fsRelation.sparkSession.sparkContext.defaultParallelism// 总大小:分区下所有文件 length+opencostbyteval totalBytes = selectedPartitions.flatMap(_.files.map(_.getLen + openCostInBytes)).sumval bytesPerCore = totalBytes / defaultParallelism// maxSplitBytes 后面会以这个参数为跨度,对input 进行 split// 真实场景下(文件大于128M且数量明显多于core时),maxSplitBytes为128Mval maxSplitBytes = Math.min(defaultMaxSplitBytes, Math.max(openCostInBytes, bytesPerCore))logInfo(s"Planning scan with bin packing, max size: $maxSplitBytes bytes, " +s"open cost is considered as scanning $openCostInBytes bytes.")// split后的files,有多个partitionedFile,注意此处的partitionedFile数量并不等于RDD的partition数        量                                   //分区遍历val splitFiles = selectedPartitions.flatMap { partition =>//文件遍历partition.files.flatMap { file =>val blockLocations = getBlockLocations(file)//文件可分割,orc为可分割if (fsRelation.fileFormat.isSplitable(fsRelation.sparkSession, fsRelation.options, file.getPath)) {//对每个文件进行split,每一个maxSplitBytes为一个partitionedFile,若文件小于                           maxSplitBytes,一个文件一个partitionedFile(0L until file.getLen by maxSplitBytes).map { offset =>val remaining = file.getLen - offsetval size = if (remaining > maxSplitBytes) maxSplitBytes else remainingval hosts = getBlockHosts(blockLocations, offset, size)PartitionedFile(partition.values, file.getPath.toUri.toString, offset, size, hosts)}//文件不可分割,如tgz,一个文件一个partiiiton} else {val hosts = getBlockHosts(blockLocations, 0, file.getLen)Seq(PartitionedFile(partition.values, file.getPath.toUri.toString, 0, file.getLen, hosts))}}}.sortBy(_.length)(implicitly[Ordering[Long]].reverse)val partitions = new ArrayBuffer[FilePartition]val currentFiles = new ArrayBuffer[PartitionedFile]var currentSize = 0L/** Close the current partition and move to the next. */def closePartition(): Unit = {if (currentFiles.nonEmpty) {val newPartition =FilePartition(partitions.size,currentFiles.toArray) // Copy to a new Array.partitions += newPartition}currentFiles.clear()currentSize = 0}// 使用next fit 近似算法将x个partitionedFile 分配入 y个partititon中// Assign files to partitions using "Next Fit Decreasing"splitFiles.foreach { file =>if (currentSize + file.length > maxSplitBytes) {closePartition()}// Add the given file to the current partition.currentSize += file.length + openCostInBytescurrentFiles += file}closePartition()new FileScanRDD(fsRelation.sparkSession, readFile, partitions)}
Next Fit算法简介
  • NF 算法是用来解决装箱问题的,装箱问题描述如下: S=(S1,S2,…Sn),其中0< Si ≤ 1, Si称之为第i个物体的体积(或重量),1≤i≤n,现有n个容积(或载重量)为1 的箱子,要求如何设法将S1,S2,…Sn放入尽可能少的箱中

  • 为partitionedFile 分配Partition类似装箱问题,经过inputsplit后,有N个小于maxSplitBytes 的partitionedFile,每个partition的容量为maxSplitBytes,如何将partitionedFile装入更少的partition中

  • NF算法的处理方法是始终维持一个当前打开的箱子,对于每一个要装入的物品,检查该物品是否可以放入当前打开的箱子,如果无法装入,则打开一个空箱子,装入该物品,以该箱子作为当前的箱子 。

  • spark先将split好的partitionedFile 按照size从大到小排序,然后依次装入到size为maxSplitBytes的partition中,装不下则打开下一个分区,直到所有partitionedFile 都被分配完毕,使用的partition数量就是此RDD partition的数量。

问题

SplitBytes 不是 64m 的整数倍时,orcReader会跨越stripe读取,会不会造成读取的数据不完整?

不会导致读取数据错误,ORC 自身的reader 接口支持按偏移量进行读取。

具体读取方式 后面在详细了解

部分参数解释
Property Name Default Meaning
spark.sql.shuffle.partitions 200 Configures the number of partitions to use when shuffling data for joins or aggregations.
spark.default.parallelism For distributed shuffle operations like reduceByKey and join, the largest number of partitions in a parent RDD. For operations like parallelize with no parent RDDs, it depends on the cluster manager: - Local mode: number of cores on the local machine - Mesos fine grained mode: 8 - Others: total number of cores on all executor nodes or 2, whichever is larger Default number of partitions in RDDs returned by transformations like join, reduceByKey, and parallelize when not set by user.

看起来它们的定义似乎也很相似,但在实际测试中,

  • spark.default.parallelism只有在处理RDD时才会起作用,对Spark SQL的无效, inputsplit 时也用到了此参数。
  • spark.sql.shuffle.partitions则是对sparks SQL专用的设置

spark sql orc Vectorized 分析

在Spark2.3.0的release中,支持了ORC Vectored,提到ORC Vectored带来的性能提升:

  • 提高scan吞吐2-5倍;

    使用ORC Vector需要满足以下条件

  • 开启 spark.sql.orc.impl =native

  • 开启 spark.sql.orc.enableVectorizedReader: 默认true;

  • 开启spark.sql.codegen.wholeStage: 默认true并且其scheme的长度不大于 wholeStageMaxNumFields(默认100列);

  • [关键]所有列数据类型需要为AtomicType类型的;

​ AtomicType代表了非 null/UDTs/arrays/structs/maps类型

OrcColumnarBatchReader 读取类分析

读取一个file的数据时,orcfileformat(orc的读写入口)会先初始化一个默认orcReader用来做schema验证,初始化Vector等操作,然后调用OrcColumnarBatchReader的initialize(),initBatch(),nextBatch()等方法进行数据读取。

  • initialize(): 初始化OrcFile Reader及Hadoop环境配置,会初始化一个带有start,end,sarg 等条件的orcReader

  • initBatch(): 初始化batch变量和columnarBatch变量(其中batch为ORC Reader矢量化每次读取的结果存储变量,columnarBatch为codegen转换为Spark定义类型存储变量 );

    读取时会根据copyTospark参数判断是复制还是引用orc Vector。

  • nextBatch(): 迭代器,其核心还是调用ORC自定义的vectored函数,需要根据类型转换Spark定义type;

性能比较
Native ORC Vectorized > Native ORC Vectorized with copy > Native ORC MR > Hive built-in ORC 

Tips

  1. 尽量使用 Native ORC Vectorized 读取方式
  2. spark.sql.defaultMaxSplitBytes = orc.stripe.size = hdfs.block.size ,设置为64m的整数倍
  3. orc.file.size 要大于defaultMaxSplitBytes ,尽量为defaultMaxSplitBytes 的整数倍。
  4. spark.sql.shuffle.partitions,要根据集群业务和core数量设置,默认200往往不是最佳

感谢以下文章,借鉴了其中不少篇幅

https://blog.csdn.net/CRISPY_RICE/article/details/79452007

https://segmentfault.com/a/1190000021297920

https://www.cnblogs.com/zlslch/p/5942204.html

https://blog.csdn.net/x_i_y_u_e/article/details/46765093

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

相关文章

  1. MR程序案例 手机流量统计

    //需求分析:对上一个MR程序生成的文件再处理:按照总流量进行倒序输出。 //MapReduce(shuffle阶段)只能按照key进行排序, //那么Mapper输出的时候应该以FlowBean对象(实现了WritableComparable --> 变成了可持久化与可比较)为key,然后让shuffle去排序。最后在Reduce阶…...

    2024/4/28 2:59:41
  2. Angular compiler报的一个错误消息:Component XX is not part of any NgModule

    Error in /turbo_modules/@angular/compiler@9.1.12/bundles/compiler.umd.js (29363:23) Component ProductListComponent is not part of any NgModule or the module has not been imported into your module.错误分析 app.module.ts里,只import了ProductListComponent,但…...

    2024/4/7 12:08:33
  3. 解决ElementUI导航栏中的vue-router在3.0版本以上重复点菜单报错问题

    在路由规则里的Vue.use(VueRouter)下面加上 const originalPush = VueRouter.prototype.push VueRouter.prototype.push = function push (location) {return originalPush.call(this, location).catch(err => err) }...

    2024/4/7 6:29:27
  4. js中的执行上下文,菜鸟入门基础。

    console.log(a); //Uncaught ReferenceError: a is not defined因为没有定义a所以报错了。var a = 52; console.log(a); //52有定义a,并且给a赋值了52所以打印a就是52。console.log(a); //undefined var a = 52; 虽然有定义a但是打印却在变量a的前面,那为什么不是报错而是打印…...

    2024/4/7 13:05:21
  5. 嵌入式实时操作系统uC/OS-II(二)

    uC/OS-II中的任务uC/OS-II的任务由如图2-1所示的三个部分组成:任务程序代码(函数)、任务堆栈和任务控制块。任务控制块就是关联任务代码的程序控制块,其记录了任务的各个属性;任务堆栈用于保存任务的工作环境。图2-1 uC/OS-II任务的组成进程和线程的区分根据任务是否具有…...

    2024/4/24 16:43:51
  6. Paddlepaddle目标检测生成端侧模型离线动态量化步骤及分类模型离线静态量化步骤

    paddlepaddle给我的感觉就是它确实方便,但是坑也确实很多,而遇到的问题坑丢到百度又没几个已经趟过的大佬。跟着官方教程来也会有各种小bug,当然不可否认tensorflow也有这样的问题。很明显,下图可以看出优秀程度:量化训练>离线静态l量化>动态离线量化训练和离线静态…...

    2024/4/19 14:32:29
  7. 解决无法找到/misc/cd目录的问题

    解决方案: 1.yum -y install autofs 2.systemctl enable --now autofs 3.systemctl status autofs 4.ls /misc/cd 5.cd /misc/cd...

    2024/4/17 4:34:03
  8. 半导体激光器与LED (发光二极管)的区别

    ...

    2024/4/7 6:50:22
  9. Android工程中配置OpenCV

    本文记录在Android studio中配置OpenCV,并利用其进行简单的图像处理,将结果图像显示出来,主要用到JNI技术。 环境安装安装Android相关环境 各个系统下安装都是大同小异,安装jdk,sdk,ndk,AS,可以参考以下博客: 安装Android Studio Ubuntu: Ubuntu18.04安装Android Studio W…...

    2024/4/7 13:41:18
  10. 快速上手moment.js

    安装 npm install moment组件中使用 <script> import moment from moment; export default {data() {return {data: [moment().format(yyyy-MM-DD HH:mm:ss), moment().add(1, day).format(yyyy-MM-DD HH:mm:ss)] //2020-08-11 00:00:00,2020-08-12 00:00:00}} } </s…...

    2024/4/20 11:44:55
  11. Spring boot images调优/缩小尺寸

    用单层镜像方法优化Docker中的Springbootdocker springboot项目镜像优化Docker优化Springboot应用程序...

    2024/4/16 19:27:07
  12. Java中的Stream流方式

    一、基础案例/*使用Stream流的方式,遍历集合,对集合中的数据进行过滤Stream流是JDK1.8之后出现的关注的是做什么,而不是怎么做*/ public class Demo01Stream {public static void main(String[] args) {//创建一个list集合,存储姓名List<String> list=new ArrayList&…...

    2024/4/22 6:18:07
  13. python深度学习笔记(一)——numpy篇(上)

    python深度学习笔记(一)——numpy篇(上)numpy基础(上)文件读取创建一个numpy矩阵利用切片操作取出数据数据判断与(&)非(|)判断强制类型转换极值求和操作 numpy基础(上) 在本节中,将记录一些简单的numpy操作,如文件读取、创建数组、数据判断、与非判断、强制类…...

    2024/4/7 12:49:24
  14. supervisord 监听多服务

    安装centos 7 : yum install supervisor -ycentos 8 : dnf install supervisor -y容器安装: apk add --no-cache --virtual supervisor (需要公网访问权限,FROM采用 alpine:3.9)配置文件默认目录:/etc/supervisor.conf /etc/supervisor.d/*.ini*.ini 配置方法[program:nginx…...

    2024/4/9 0:41:21
  15. 【框架专题】——工具型框架——Myabtis原理(2)——mapper注入替换原理

    Myabtis源码——mapper注入原理(1)knownMappers初始化继续一步xmlMapperBuilder.parse(),我主要关心mapper接口如何跟xml连接起来呢?来mapper代理对象和xml的sql内容组装在一起,向数据库发起sql请求,我们继续xmlMapperBuilder.parse(),看看!public class XMLMapperBuil…...

    2024/4/25 12:49:10
  16. SSLOJ 1459.空间简单度

    ...题意:分析:代码:题意: 给出一棵树以及若干条边 给出一个定值kkk,求有多少条路径的空间简单度>k>k>k 而空间简单度的定义如下:分析: 这道题和JZOJ(GMOJ) P6276JZOJ(GMOJ)\ \ \ \ P6276JZOJ(GMOJ) P6276几乎一样 思路就是将众多包含不合法的点对的路径在…...

    2024/4/8 23:52:42
  17. ElasticSearch的IK分词器详细安装教程及使用实操

    1. IK分词器NOTE: 默认ES中采用标准分词器进行分词,这种方式并不适用于中文网站,因此需要修改ES对中文友好分词,从而达到更佳的搜索的效果。1.1 在线安装IK在线安装IK (v5.5.1版本后开始支持在线安装 )# 0.必须将es服务中原始数据删除 - 进入es安装目录中将data目录数据删除rm…...

    2024/4/9 0:11:19
  18. 拳王虚拟项目公社:利用减肥健身类虚拟资源项目,如何打造一套赚钱系统?

    现代人生活条件是越来越好,当然节奏是越来越快,社会交际也几乎围绕饭局、酒吧、KT、夜宵等有数的几种场所,即使许多女性朋友节制饮食,也阻挡不了肥胖的来袭。 一味的从吃喝上控制不考虑运动消耗,肥胖是必然的结果。肥胖之后随之而来的问题就是——减肥!光是贴吧的关注人数…...

    2024/4/8 19:33:58
  19. Y赞滑块逆向

    好久没写文章了,最近刚转正比较忙,今天有空把业务中写过的一个滑块来给大家讲讲吧。 话不多说直接上网站:aHR0cHMlM0EvL2FjY291bnQueW91emFuLmNvbS9sb2dpbg== 直接开搞: 第一步;抓包分析:我们多刷新抓几次包分析可以得到下面这些结论: token:统一请求标识 bizType:固定 …...

    2024/4/25 14:33:00
  20. Leetcode563(力扣563):二叉树的坡度

    class Solution {int res=0;int dfs(TreeNode* root) {if(!root) return 0;int left=dfs(root->left);int right=dfs(root->right);res+=abs(left-right);return root->val+left+right;} public:int findTilt(TreeNode* root) {dfs(root);return res;} };...

    2024/4/9 14:04:14

最新文章

  1. springboot 集成 activemq

    文章目录 一&#xff1a;说明二&#xff1a;e-car项目配置1 引入activemq依赖2 application启动类配置消息监听3 application.yml配置4 MQConfig.java 配置类5 ecar 项目中的监听6 junit 发送消息 三&#xff1a;tcm-chatgpt项目配置5 MQListener.java 监听消息 三 测试启动act…...

    2024/4/28 8:25:59
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 【opencv】示例-ela.cpp JPEG图像的错误等级分析(ELA) 通过分析图像压缩后的差异来检测图像是否被篡改过...

    ela_modified.jpg 原始ela_modified压缩后再解压得到compressed_img 差异图像Ela 这段代码的功能是实现JPEG图像的错误等级分析&#xff08;ELA&#xff09;&#xff0c;通过分析图像压缩后的差异来检测图像是否被篡改过。程序会首先读取一张图片&#xff0c;然后对其应用质量…...

    2024/4/18 3:59:10
  4. 蓝桥杯加训

    1.两只塔姆沃斯牛&#xff08;模拟&#xff09; 思路&#xff1a;人和牛都记录三个数据&#xff0c;当前坐标和走的方向&#xff0c;如果人和牛的坐标和方向走重复了&#xff0c;那就说明一直在绕圈圈&#xff0c;无解 #include<iostream> using namespace std; const i…...

    2024/4/27 19:03:08
  5. OpenHarmony开发-连接开发板调试应用

    在 OpenHarmony 开发过程中&#xff0c;连接开发板进行应用调试是一个关键步骤&#xff0c;只有在真实的硬件环境下&#xff0c;我们才能测试出应用更多的潜在问题&#xff0c;以便后续我们进行优化。本文详细介绍了连接开发板调试 OpenHarmony 应用的操作步骤。 首先&#xf…...

    2024/4/27 20:51:51
  6. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/4/28 4:04:40
  7. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/4/27 3:39:11
  8. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/4/27 12:24:35
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/4/27 12:24:46
  10. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/4/27 3:39:08
  11. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/4/27 3:39:07
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/4/27 3:39:07
  13. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/4/27 12:44:49
  14. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/4/27 21:08:20
  15. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/4/26 22:35:59
  16. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/4/27 18:40:35
  17. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/4/28 4:14:21
  18. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/4/27 13:52:15
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/4/27 13:38:13
  20. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/4/27 1:03:20
  21. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/4/27 3:22:12
  22. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/4/27 22:51:49
  23. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/4/28 7:31:46
  24. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/4/26 23:53:24
  25. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/4/27 20:28:35
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57