Shuffle文件寻址

  • MapOutputTracker

      MapOutputTracker是Spark架构中的一个模块,是一个主从架构。管理磁盘小文件的地址。

  1. MapOutputTrackerMaster是主对象,存在于Driver中
  2. MapOutputTrackerWorker是从对象,存在于Excutor中
  • BlockManager

      BlockManager块管理者,是Spark架构中的一个模块,也是一个主从架构。

  1. BlockManagerMaster,主对象,存在于Driver中

         BlockManagerMaster会在集群中有用到广播变量和缓存数据或者删除缓存数据的时候,通知BlockManagerSlave传输或者删除数据。

      2.BlockManagerSlave,从对象,存在于Excutor中

         BlockManagerSlave会与BlockManagerSlave之间通信。

  • 无论在Driver端的BlockManager还是在Excutor端的BlockManager都含有三个对象:
  1. DiskStore:负责磁盘的管理。
  2. MemoryStore:负责内存的管理。
  3. BlockTransferService:负责数据的传输。
  • Shuffle文件寻址图

Spark _18 _Shuffle文件寻址

  • Shuffle文件寻址流程
  1. 当map task执行完成后,会将task的执行情况和磁盘小文件的地址封装到MpStatus对象中,通过MapOutputTrackerWorker对象向Driver中的MapOutputTrackerMaster汇报。
  2. 在所有的map task执行完毕后,Driver中就掌握了所有的磁盘小文件的地址。
  3. 在reduce task执行之前,会通过Excutor中MapOutPutTrackerWorker向Driver端的MapOutputTrackerMaster获取磁盘小文件的地址。
  4. 获取到磁盘小文件的地址后,会通过BlockManager连接数据所在节点,然后通过BlockTransferService进行数据的传输。
  5. BlockTransferService默认启动5个task去节点拉取数据。默认情况下,5个task拉取数据量不能超过48M。

相关文章:

  • 2021-06-27
  • 2021-11-07
  • 2021-12-23
  • 2021-10-23
  • 2021-10-01
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-09-22
  • 2021-05-26
  • 2021-11-21
  • 2021-11-21
  • 2021-07-01
  • 2021-06-10
  • 2021-10-02
相关资源
相似解决方案