码迷,mamicode.com
首页 > 其他好文 > 详细

总结的MR中连接操作

时间:2014-09-20 21:12:39      阅读:262      评论:0      收藏:0      [点我收藏+]

标签:文件   sp   c   r   bs   file   不同的   方法   总结   

1 reduce side join
在map端加上标记, 在reduce容器保存,然后作笛卡尔积
缺点: 有可能oom

2 map side join
 2.1 利用内存和分布式缓存,也有oom风险
 2.2 自己的想法,参考hive桶的思路,
  第一次MR,将两个文件相同的方法分文件输出并打上标记,排序输出,尽可能分的比较均匀
  第二次MR 改写输入方法,将相同标记的多个分片打包传给map, 改写读的方法,用数组或者列表保存文件流,利用多个文件多路归并思想,使整个大分片按照有序的方法传给map,
MAP方法中,保存当前的连接key, 然后用容器分标示保存连接key,每次有新的连接key进来,判断是否与上一个连接key相同,如果不同,则输出 容器的笛卡尔积, 否则则添加进容器
  优点: 减少笛卡尔积,分片打包时,如果有个标示没有,整个分片都可以丢掉,减少判断
  缺点: 如果连接key过多, 还是有oom风险.

  改进思路,在文件读取时,根据文件读取相同标示的分片内容(首选文件小的),Map中保存, 读完再读取另外一个文件标示下的文件,如果连接key相同,则和容器中保存的值做连接输出,一直读到不同的key为止,继续连续读上一个标示的key
  优点: 减少了一个容器来做笛卡尔积,只用保存小的标示文件,然后和大文件做笛卡尔积
  缺点: 如果小文件单个key的数量很大, 还是会有oom风险

3 半连接
  主要利用过滤,将要文件中要关联的字段抽取出来,保存成一个文件, 利用分布式缓存读入内存过滤,如果文件过大可以利用bloomfile, 可能牺牲了一点精确度,但是在reduce端还是会过滤
  风险: 还是有oop风险

总结的MR中连接操作

标签:文件   sp   c   r   bs   file   不同的   方法   总结   

原文地址:http://www.cnblogs.com/chengxin1982/p/3983667.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!