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

全球外贸网站有哪些软件开发模型及特点

全球外贸网站有哪些,软件开发模型及特点,乐清建站,如何上传安装网站模板目录 1.广播变量#xff08;broadcast variables#xff09; 2.累加器#xff08;accumulators#xff09; 在分布式计算中#xff0c;当在集群的多个节点上并行运行函数时#xff0c;默认情况下#xff0c;每个任务都会获得函数中使用到的变量的一个副本。如果变量很…目录 1.广播变量broadcast variables 2.累加器accumulators 在分布式计算中当在集群的多个节点上并行运行函数时默认情况下每个任务都会获得函数中使用到的变量的一个副本。如果变量很大这会导致网络传输占用大量带宽并且在每个节点上都占用大量内存空间。为了解决这个问题Spark引入了共享变量的概念。 共享变量允许在多个任务之间共享数据而不是为每个任务分别复制一份变量。这样可以显著降低网络传输的开销和内存占用。Spark提供了两种类型的共享变量广播变量broadcast variables和累加器accumulators。 1.广播变量broadcast variables 通常情况下Spark程序运行时通常会将数据以副本的形式分发到每个执行器Executor的任务Task中但当变量较大时这会导致大量的内存和网络开销。通过使用广播变量Spark将变量只发送一次到每个节点并在多个任务之间共享这个副本从而显著降低了内存占用和网络传输的开销。 Scala 实现 scala val broadcastVar sc.broadcast(Array(1, 2, 3)) broadcastVar: org.apache.spark.broadcast.Broadcast[Array[Int]] Broadcast(0)scala broadcastVar.value res0: Array[Int] Array(1, 2, 3) Java 实现 Broadcastint[] broadcastVar sc.broadcast(new int[] {1, 2, 3});broadcastVar.value(); // returns [1, 2, 3] 2.累加器accumulators 累加器是Spark中的一种特殊类型的共享变量主要用来把Executor端变量信息聚合到Driver端。在Driver程序中定义的变量在Executor端的每个task都会得到这个变量的一份新的副本每个task更新这些副本的值后传回Driver端进行merge。累加器支持的数据类型仅限于数值类型包括整数和浮点数等。 Scala 实现 scala val accum sc.longAccumulator(My Accumulator) accum: org.apache.spark.util.LongAccumulator LongAccumulator(id: 0, name: Some(My Accumulator), value: 0)scala sc.parallelize(Array(1, 2, 3, 4)).foreach(x accum.add(x)) ... 10/09/29 18:41:08 INFO SparkContext: Tasks finished in 0.317106 sscala accum.value res2: Long 10 Java 实现 LongAccumulator accum jsc.sc().longAccumulator();sc.parallelize(Arrays.asList(1, 2, 3, 4)).foreach(x - accum.add(x)); // ... // 10/09/29 18:41:08 INFO SparkContext: Tasks finished in 0.317106 saccum.value(); // returns 10 内置累加器功能有限但可以通过继承AccumulatorV2来创建自己的类型。AccumulatorV2抽象类有几个方法必须重写reset用于将累加器重置为零add用于向累加器中添加另一个值merge用于将另一个相同类型的累加器合并到此累加器。 自定义累加器Scala实现 package com.yichenkeji.demo.sparkscalaimport org.apache.spark.util.AccumulatorV2class CustomAccumulator extends AccumulatorV2[Int, Int]{//初始化累加器的值private var sum 0override def isZero: Boolean sum 0override def copy(): AccumulatorV2[Int, Int] {val newAcc new CustomAccumulator()newAcc.sum sumnewAcc}override def reset(): Unit sum 0override def add(v: Int): Unit sum voverride def merge(other: AccumulatorV2[Int, Int]): Unit sum other.valueoverride def value: Int sum }自定义累加器Java实现 package com.yichenkeji.demo.sparkjava;import org.apache.spark.util.AccumulatorV2;public class CustomAccumulator extends AccumulatorV2Integer, Integer {// 初始化累加器的值private Integer sum 0;Overridepublic boolean isZero() {return sum 0;}Overridepublic AccumulatorV2Integer, Integer copy() {CustomAccumulator customAccumulator new CustomAccumulator();customAccumulator.sum this.sum;return customAccumulator;}Overridepublic void reset() {this.sum 0;}Overridepublic void add(Integer v) {this.sum v;}Overridepublic void merge(AccumulatorV2Integer, Integer other) {this.sum ((CustomAccumulator) other).sum;}Overridepublic Integer value() {return sum;} }自定义累加器的使用 package com.yichenkeji.demo.sparkjava;import org.apache.spark.SparkConf; import org.apache.spark.api.java.JavaRDD; import org.apache.spark.api.java.JavaSparkContext; import org.apache.spark.api.java.function.Function;import java.util.Arrays; import java.util.List;public class AccumulatorTest {public static void main(String[] args) {//1.初始化SparkContext对象SparkConf sparkConf new SparkConf().setAppName(Spark Java).setMaster(local[*]);JavaSparkContext sc new JavaSparkContext(sparkConf);CustomAccumulator customAccumulator new CustomAccumulator();//注册自定义累加器才能使用sc.sc().register(customAccumulator);sc.parallelize(Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)).foreach(x - customAccumulator.add(x));System.out.println(customAccumulator.value());//5.停止SparkContextsc.stop();} }
http://www.zqtcl.cn/news/520196/

相关文章:

  • 百度资料怎么做网站赣州有没有做网站的
  • 网站上地图怎么做的福建省晋江市建设局网站
  • 休闲咖啡厅网站开发目标站内推广的方法和工具
  • 东莞做营销型网站怎样利用网站做引流
  • 国际1688网站网络平台宣传费用
  • 免费网站自助建站18款禁游戏黄app入口
  • 网站建设要经历哪些步骤?wordpress主题king
  • 个人定制网站外贸免费网站建设
  • ASP网站建设实训报告总结宜昌本地网站建设
  • 甘肃省建设厅官方网站张睿建立网站服务器
  • 有没有做博物馆的3d网站网页美工设计岗前培训
  • 如何防止网站被盗长沙知名网站建设
  • 汕尾住房和建设局网站山西招标网
  • 网站建设那好山西建设厅网站
  • 2免费做网站外贸公司注册需要多少钱
  • 莘县网站定制安卓软件开发培训机构
  • 织梦视频网站源码有没有专门做名片的网站
  • 济南本地网站自己做的网站怎么置顶
  • wordpress能做多大的站好用的网站后台
  • 想自己做网站流程国家住建网查企业资质
  • 英文网站怎么设计google浏览器入口
  • 重庆网站建设公司魁网个人备案网站名
  • 怀柔营销型网站建设wordpress菜单定制
  • 大连装修网站推广天津市建设信息工程网
  • 服装网站建设建议域名注册最好的网站
  • 小游戏网站网络营销推广岗位
  • 做一百度网站保健品网站建设案例
  • 沙田镇仿做网站如何建设钓鱼网站
  • 如何用域名进网站企业做电商网站有哪些
  • soho做网站网站的k线图怎么做