内容简介:其实我们可以从word count这个实例来理解MapReduce。MapReduce大体上分为六个步骤:input, split, map, shuffle, reduce, output。细节描述如下:使用下面语句对status_code各种key进行统计也可以只显示状态为200的条目
map reduce的解释
这是一张来自mongodb-mapreduce图示,比较能说明问题
其实我们可以从word count这个实例来理解MapReduce。MapReduce大体上分为六个步骤:input, split, map, shuffle, reduce, output。细节描述如下:
- 输入(input):如给定一个文档,包含如下四行:
Hello Java
Hello C
Hello Java
Hello C++ - 拆分(split):将上述文档中每一行的内容转换为key-value对,即:
0 - Hello Java
1 - Hello C
2 – Hello Java
3 - Hello C++ - 映射(map):将拆分之后的内容转换成新的key-value对,即:
(Hello , 1)
(Java , 1)
(Hello , 1)
(C , 1)
(Hello , 1)
(Java , 1)
(Hello , 1)
(C++ , 1) - 派发(shuffle):将key相同的扔到一起去,即:
(Hello , 1)
(Hello , 1)
(Hello , 1)
(Hello , 1)
(Java , 1)
(Java , 1)
(C , 1)
(C++ , 1)
注意:这一步需要移动数据,原来的数据可能在不同的datanode上,这一步过后,相同key的数据会被移动到同一台机器上。最终,它会返回一个list包含各种k-value对,即:
{ Hello: 1,1,1,1}
{Java: 1,1}
{C: 1}
{C++: 1} - 缩减(reduce):把同一个key的结果加在一起。如:
(Hello , 4)
(Java , 2)
(C , 1)
(C++,1) - 输出(output): 输出缩减之后的所有结果。
{ "_id" : ObjectId("5a79391534cdbd692825e978"), "cdn" : "Conversant", "domain" : "7img1.xxxx.com", "status_code" : { "200" : 80, "206" : 3, "404" : 2, "304" : 4 } }
使用下面语句对status_code各种key进行统计
db.getCollection('log_coll').mapReduce( function(){ var codes = this.status_code; Object.keys(codes).forEach(function(k){ emit(k, codes[k]); }) }, function(k, v){ return Array.sum(v); }, { out : {inline : 1}, query: {} } )
也可以只显示状态为200的条目
db.getCollection('log_coll').mapReduce( function(){ var codes = this.status_code; Object.keys(codes).forEach(function(k){ if(codes[k].id=="200"){ emit(k, codes[k]); } }) }, function(k, v){ return Array.sum(v); }, { out : {inline : 1}, query: {} } )
多级对象如果判断各级对象是否存在
db.getCollection('client_accounts').mapReduce( function(){ if(this.client!=undefined){ if(this.client.employees!=undefined) { var codes = this.client.employees; Object.keys(codes).forEach(function(k){ emit(k, codes[k]); }) } } }, function(k, v){ }, { out : {inline : 1}, query: {} } )
## 下面看多条件分组的mapreduce实现
我将多个条件拼接在一起方便查看,正式环境时可以使用js对象。
db.customerWorkloadTotal.mapReduce( function() { emit(this.salespersonId + "_" + this.customerId, this); }, function(key, values) { tagIntention = 0; signCustomerNums = 0; trackContactNums = 0; values.forEach(function(v) { if (v.tagIntention > 0) { tagIntention = v.tagIntention; } if (v.signCustomerNums > 0) { signCustomerNums = 1; } if (v.trackContactNums > 0) { trackContactNums = 1; } }); return { "tagIntention": tagIntention, "signCustomerNums": signCustomerNums, "trackContactNums": trackContactNums }; }, { query: { totalDate: { $gte: "2018-10-31" } }, sort: { totalDate: -1 }, out: { inline: 1 } } ).find()
以上所述就是小编给大家介绍的《mongodb~mapreduce的实现特殊逻辑的统计》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 统计关系学习综述(转载),贝叶斯逻辑程序相关内容,超高难度(part1)
- 微信小程序数据统计和错误统计的实现
- 机器学习数学基础:数理统计与描述性统计
- centos创建逻辑卷和扩容逻辑卷
- AI「王道」逻辑编程的复兴?清华提出神经逻辑机,已入选ICLR
- 内聚代码提高逻辑可读性,用MCVP接续你的大逻辑
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Effective Ruby:改善Ruby程序的48条建议
Peter J. Jones / 杨政权、秦五一、孟樊超 / 机械工业出版社 / 2016-1 / 49
如果你是经验丰富的Rub程序员,本书能帮助你发挥Ruby的全部力量来编写更稳健、高效、可维护和易执行的代码。Peter J.Jones凭借其近十年的Ruby开发经验,总结出48条Ruby的最佳实践、专家建议和捷径,并辅以可执行的代码实例。 Jones在Ruby开发的每个主要领域都给出了实用的建议,从模块、内存到元编程。他对鲜为人知的Ruby方言、怪癖、误区和强力影响代码行为与性能的复杂性的揭......一起来看看 《Effective Ruby:改善Ruby程序的48条建议》 这本书的介绍吧!