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

手机端网站如何做排名靠前营销网站建设免费

手机端网站如何做排名靠前,营销网站建设免费,wordpress 许愿墙,开发公司发言稿观摩会本套系列博客从真实商业环境抽取案例进行总结和分享,并给出Spark源码解读及商业实战指导,请持续关注本套博客。版权声明:本套Spark源码解读及商业实战归作者(秦凯新)所有,禁止转载,欢迎学习。 S…

本套系列博客从真实商业环境抽取案例进行总结和分享,并给出Spark源码解读及商业实战指导,请持续关注本套博客。版权声明:本套Spark源码解读及商业实战归作者(秦凯新)所有,禁止转载,欢迎学习。

Spark商业环境实战及调优进阶系列

  • Spark商业环境实战-Spark内置框架rpc通讯机制及RpcEnv基础设施
  • Spark商业环境实战-Spark事件监听总线流程分析
  • Spark商业环境实战-Spark存储体系底层架构剖析
  • Spark商业环境实战-Spark底层多个MessageLoop循环线程执行流程分析
  • Spark商业环境实战-Spark二级调度系统Stage划分算法和最佳任务调度细节剖析
  • Spark商业环境实战-Spark任务延迟调度及调度池Pool架构剖析
  • Spark商业环境实战-Task粒度的缓存聚合排序结构AppendOnlyMap详细剖析
  • Spark商业环境实战-ExternalSorter 排序器在Spark Shuffle过程中设计思路剖析
  • Spark商业环境实战-StreamingContext启动流程及Dtream 模板源码剖析
  • Spark商业环境实战-ReceiverTracker与BlockGenerator数据流接收过程剖析

1. Spark存储体系组件关系解释

BlockInfoManger 主要提供读写锁控制,层级仅仅位于BlockManger之下,通常Spark读写操作都先调用BlockManger,然后咨询BlockInfoManger是否存在锁竞争,然后才会调用DiskStore和MemStore,进而调用DiskBlockManger来确定数据与位置映射,或者调用 MemoryManger来确定内存池的软边界和内存使用申请。

1.1 Driver 与 Executor 与 SparkEnv 与 BlockManger 组件关系:

Driver与 Executor 组件各自拥有任务执行的SparkEnv环境,而每一个SparkEnv 中都有一个BlockManger负责存储服务,作为高层抽象,BlockManger 之间需要通过 RPCEnv,ShuffleClient,及BlocakTransferService相互通讯。

1.1 BlockInfoManger 与 BlockInfo 共享锁和排它锁读写控制关系:

BlockInfo中具有读写锁的标志,通过标志可以判断是否进行写控制

  val NO_WRITER: Long = -1val NON_TASK_WRITER: Long = -1024* The task attempt id of the task which currently holds the write lock for this block, or* [[BlockInfo.NON_TASK_WRITER]] if the write lock is held by non-task code, or* [[BlockInfo.NO_WRITER]] if this block is not locked for writing.def writerTask: Long = _writerTaskdef writerTask_=(t: Long): Unit = {_writerTask = tcheckInvariants()
复制代码

BlockInfoManager具有BlockId与BlockInfo的映射关系以及任务id与BlockId的锁映射:

 private[this] val infos = new mutable.HashMap[BlockId, BlockInfo]  *Tracks the set of blocks that each task has locked for writing.private[this] val writeLocksByTask = new mutable.HashMap[TaskAttemptId, mutable.Set[BlockId]]with mutable.MultiMap[TaskAttemptId, BlockId]*Tracks the set of blocks that each task has locked for reading, along with the number of times*that a block has been locked (since our read locks are re-entrant).private[this] val readLocksByTask =new mutable.HashMap[TaskAttemptId, ConcurrentHashMultiset[BlockId]]
复制代码

1.3 DiskBlockManager 与 DiskStore 组件关系:

可以看到DiskStore内部会调用DiskBlockManager来确定Block的读写位置:

  • 以下是DiskStore的抽象写操作,需要传入FileOutputStream => Unit高阶函数:

      def put(blockId: BlockId)(writeFunc: FileOutputStream => Unit): Unit = {if (contains(blockId)) {throw new IllegalStateException(s"Block $blockId is already present in the disk store")}logDebug(s"Attempting to put block $blockId")val startTime = System.currentTimeMillisval file = diskManager.getFile(blockId)val fileOutputStream = new FileOutputStream(file)var threwException: Boolean = truetry {writeFunc(fileOutputStream)threwException = false} finally {try {Closeables.close(fileOutputStream, threwException)} finally {if (threwException) {remove(blockId)}}}val finishTime = System.currentTimeMillislogDebug("Block %s stored as %s file on disk in %d ms".format(file.getName,Utils.bytesToString(file.length()),finishTime - startTime))}
    复制代码
  • 以下是DiskStore的读操作,调用DiskBlockManager来获取数据位置:

      def getBytes(blockId: BlockId): ChunkedByteBuffer = {val file = diskManager.getFile(blockId.name)val channel = new RandomAccessFile(file, "r").getChannelUtils.tryWithSafeFinally {
    * For small files, directly read rather than memory mapif (file.length < minMemoryMapBytes) {val buf = ByteBuffer.allocate(file.length.toInt)channel.position(0)while (buf.remaining() != 0) {if (channel.read(buf) == -1) {throw new IOException("Reached EOF before filling buffer\n" +s"offset=0\nfile=${file.getAbsolutePath}\nbuf.remaining=${buf.remaining}")}}buf.flip()new ChunkedByteBuffer(buf)} else {new ChunkedByteBuffer(channel.map(MapMode.READ_ONLY, 0, file.length))}} {channel.close()}}
    复制代码

1.3 MemManager 与 MemStore 与 MemoryPool 组件关系:

在这里要强调的是:第一代大数据框架hadoop只将内存作为计算资源,而Spark不仅将内存作为计算资源外,还将内存的一部分纳入存储体系:

  • 内存池模型 :逻辑上分为堆内存和堆外内存,然后堆内存(或堆外内存)内部又分为StorageMemoryPool和ExecutionMemoryPool。
  • MemManager是抽象的,定义了内存管理器的接口规范,方便以后扩展,比如:老版的StaticMemoryManager和新版的UnifiedMemoryManager.
  • MemStore 依赖于UnifiedMemoryManager进行内存的申请和软边界变化或内存释放。
  • MemStore 内部同时负责存储真实的对象,比如内部成员变量:entries ,建立了内存中的BlockId与MemoryEntry(Block的内存的形式)之间的映射。
  • MemStore 内部的“占座”行为,如:内部变量offHeapUnrollMemoryMap 和onHeapUnrollMemoryMap。

1.4 BlockManagerMaster 与 BlockManager 组件关系:

  • BlockManagerMaster的作用就是对存在于Dirver或Executor上的BlockManger进行统一管理,这简直是代理行为,因为他持有BlockManagerMasterEndpointREf,进而和BlockManagerMasterEndpoint进行通讯。

2. Spark存储体系组件BlockTransferServic传输服务

未完待续

3. 总结

存储体系是Spark的基石,我争取把每一块细微的知识点进行剖析,和大部分博客不同的是,我会尽量采用最平实的语言,毕竟技术就是一层窗户纸。

秦凯新 20181031 凌晨

http://www.lbrq.cn/news/2492083.html

相关文章:

  • 江苏城乡住房和城乡建设厅网站百度seo策略
  • 地方门户网站用户seo网站推广优化
  • 服装公司电商网站建设规划seo优化工具有哪些
  • 帝国做的网站怎么上传关键词seo价格
  • 用.net做视频网站的案例会员制营销
  • 让人做网站 需要准备什么条件推广app的方法和策略
  • 永川做网站的公司今日最新重大新闻
  • wordpress主题发布站源码推广平台的方法
  • 网站怎么做才不会被墙企业网站优化哪家好
  • 汽车行业网站建设搜狐新闻手机网
  • 手机网站后台管理系统seo公司推荐
  • 哪家公司建设网站python培训
  • 中国有色金属建设股份有限公司网站seo在线外链
  • 永春网站设计查权重工具
  • 江西头条热点新闻搜索引擎排名优化程序
  • seo站内站怎么做青岛关键词排名提升
  • 南宁网页制作培训网站关键词优化代理
  • 有关网站建设的知识幽默软文经典案例300
  • 网站开发最新技术适合推广的app有哪些
  • 进一步加强舆情管控安徽网站关键字优化
  • 网站制作合同书上海优化seo
  • mvc电子商务网站开发网站推广怎么优化
  • 多配色创意metro风格企业网站织梦模板整lol今日赛事直播
  • 深圳哪个网站好推广一点深圳全网推广排名
  • 在网站做推广要钱吗最新疫情最新消息
  • 怎么查看网站的建设时间最新网络营销方式
  • wordpress网站例企业官方网站推广
  • 深圳企业社保网站官网百度指数怎么看城市
  • 天津网站建设揭秘登录百度
  • 网站怎样做https百度笔记排名优化
  • Android启动时间优化大全
  • vuhub jangow-01-1.0.1靶场攻略
  • 小架构step系列26:Spring提供的validator
  • 【C++】定义常量
  • Linux应用开发基础知识——Framebuffer应用编程(六)
  • OpenCV学习探秘之二 :数字图像的矩阵原理,OpenCV图像类与常用函数接口说明,及其常见操作核心技术详解