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

一流的免费网站建设黑帽seo优化推广

一流的免费网站建设,黑帽seo优化推广,购物网站服务中心,深圳航空股份有限公司Spark SQL优化机制Spark SQLCatalyst 优化器逻辑优化物理优化TungstenUnsafe RowWSCGRDD 缺点 : RDD的算子都是高阶函数 ,Spark Core 不知函数内的操作,只能闭包形式发给 Executors, 无法优化 DataFrame 不同点: 数据的表示形式…

Spark SQL优化机制

  • Spark SQL
  • Catalyst 优化器
    • 逻辑优化
    • 物理优化
  • Tungsten
    • Unsafe Row
    • WSCG

RDD 缺点 : RDD的算子都是高阶函数 ,Spark Core 不知函数内的操作,只能闭包形式发给 Executors, 无法优化

DataFrame 不同点:

  • 数据的表示形式 :有数据模式(Data Schema)的结构化数据
  • 开发算子 :一套 DSL算子(Domain Specific Language)

Spark 能用 DataFrame ,基于启发式的规则或策略,动态的运行时信息,去优化 DataFrame 的计算过程

Spark SQL

  • Spark Core :特指 Spark 底层执行引擎(Execution Engine),包括:调度系统、存储系统、内存管理、Shuffle 管理
  • Spark SQL :基于 Spark Core 上,有一层独立的优化引 (Optimization Engine)

Spark Core/Spark SQL关系:

  • Spark SQL 优化后的代码,交给 Spark Core 执行

在这里插入图片描述

Spark SQL 的两个核心组件:Catalyst 优化器 /Tungsten

  • Catalyst 优化器:负责创建并优化执行计划,有 3 个功能模块:创建语法树并生成执行计划、逻辑阶段优化、物理阶段优化
  • Tungsten :负责优化数据结果与可执行代码 ,衔接 Catalyst 执行计划与底层的 Spark Core 执行引擎

在这里插入图片描述

Catalyst 优化器

Catalyst 优化器的作用:在逻辑优化阶段,基于启发式的规则和策略调整、优化执行计划,为物理优化阶段提升性能奠定基础

逻辑优化

Catalyst 的优化过程 : 先用第三方的 SQL 解析器 ANTLR 生成抽象语法树(AST,AbstractSyntax Tree)

AST 的两个基本元素构成

  • 节点:各式各样的操作算子,如 : select、filter、agg
  • 边 : 记录了数据表的 Schema 信息 ,如 : 字段名、字段类型

AST 语法树/执行计划(Execution Plan ) :

在这里插入图片描述

Parquet 格式在文件层面支持两项特性 :

  • 谓词下推、列剪枝 :都是启发式的规则或策略
  • 谓词下推 (Predicates Pushdown) : batchNum >= 201601的过滤条件,在扫描过程时,只读取那些满足条件的数据文件
  • 列剪枝 (Columns Pruning):Parquet 是列存 (Columns Store) 数据结构,只取某个字段名的数据文件时,就会剪掉其他数据文件的过程

Spark 只扫描绿色部分 :

在这里插入图片描述

逻辑优化的执行计划 :

  • 执行顺序 : Scan > Filter > Select变成 Filter > Select > Scan

在这里插入图片描述

物理优化

Catalyst 的优化阶段差异:

  • 逻辑阶段 :依赖先验的启发式经验 , 基于经验优化
  • 物理阶段:依赖各式各样的统计信息,如:数据表尺寸、是否启用数据缓存、Shuffle 中间文件, 基于数据优化

Join 节点物理阶段优化:

  • 采用哪种实现机制实现关联:嵌套循环连接(NLJ,Nested Loop Join)、排序归并连接(Sort Merge Join)、哈希连接(Hash Join)
  • 采用哪种数据分发实现关联:Shuffle Join 和 Broadcast Join
  • 根据两张表的存储大小,决定采用 :运行稳定但性能略差的 Shuffle Sort Merge Join 或 执行性能更佳的 Broadcast Hash Join

Tungsten

基于Catalyst ,Tungsten 在数据结构/执行代码进行进一步的优化

  • 数据结构优化: Unsafe Row 的设计与实现
  • 执行代码优化:全阶段代码生成(WSCG,Whole Stage Code Generation)

Unsafe Row

Spark SQL 默认采用 org.apache.spark.sql.Row 对象对每条数据进行封装和存储,Java Object 会有大量的存储开销

Unsafe Row 是二进制数据结构,以字节数组的格式存储每条数据,能减少存储开销

采用默认的 Row存储:

  • 每条记录需要消耗至少 60 个字节

在这里插入图片描述

采用 Tungsten Unsafe Row 存储:

  • 每条数据记录仅需消耗十几个字节

在这里插入图片描述

WSCG

WSCG:全阶段代码生成

  • 全阶段:调度系统中的 Stage
  • 代码生成:运行时,把链式调用的算子合成一份代码。如:把 Filter、Select、Scan 合成一个函数

绿色节点属于同一个 Stage :

在这里插入图片描述

http://www.tj-hxxt.cn/news/91424.html

相关文章:

  • 电子商务网站的建设和流程推广什么app佣金高
  • 杨凌规划建设局网站英文外链代发
  • 淄博网站建设服务武汉百度百科
  • 手机版网站建设开发网址缩短
  • 网站编程代码大全广告公司广告牌制作
  • 上海哪家公司可以做网站做网站的公司哪家最好
  • 个体户做网站有用吗友情链接的网站
  • 图片搜集网站怎么做天天外链
  • 比较好的家装设计网站百度搜索风云榜手机版
  • flash网站模板 asp建网站的详细步骤
  • php网站培训机构企业做网站网络营销的方式都有哪些
  • 网站标题第一个词南通百度seo代理
  • 马帮erp是干嘛的天津网站优化软件
  • 自己做刷东西的网站注册网站
  • 西宁 专业网站建设企业网站建设优化
  • 网站开发合同付款方式网络营销策划方案
  • 阿里云万网网站建设靠谱吗重庆网络推广专员
  • 网站开发外包协议百度竞价是什么意思?
  • qq空间 wordpress关键词优化排名工具
  • wordpress 免费自媒体搜云seo
  • 胶州市经济技术开发区建设局网站确认已有81人感染
  • 做网站公司的商标需要注册吗北京优化seo公司
  • 怎样做写真网站网络营销服务策略
  • 泉州市住房和城乡建设部网站潍坊住房公积金
  • 成都艾邦视觉专业网站建设公司关键词歌词含义
  • 网站设计与制作的过程西安百度关键词优化排名
  • 大型门户网站建设多少钱制作网页的教程
  • 建站网站的图片关键词排名推广怎么做
  • 推广普通话的重要意义沈阳seo排名优化推广
  • 学做网站论sem和seo的区别