官术网_书友最值得收藏!

Aggregation versus MapReduce

In MongoDB, we can essentially get data out of our database using three methods: querying, the aggregation framework, and MapReduce. All three of them can be chained to each other and many times it is useful to do so; however it's important to understand when we should use aggregation and when MapReduce may be a better alternative.

We can use both aggregation and MapReduce with sharded databases.

Aggregation is based on the concept of a pipeline. As such, it's important to be able to model our data from input to final output, in a series of transformations and processing that can get us there. It's also mostly useful when our intermediate results can be used on their own, or feed parallel pipelines. Our operations are limited by the operators that we have available from MongoDB so it's important to make sure that we can calculate all the results we need using available commands.

MapReduce on the other hand, can be used to construct pipelines by chaining the output of one MapReduce job to the input of the next one via an intermediate collection but this is not its primary purpose.

MapReduce's most common use case is to periodically calculate aggregations for large datasets. Having MongoDB's querying in place we can incrementally calculate these aggregations without the need to scan through the whole input table every time. In addition, its power comes from its flexibility as we can define mappers and reducers in JavaScript with the full flexibility of the language when calculating intermediate results. Not having the operators that the aggregation framework provides us, we have to implement them on our own.

In many cases, the answer is not either/or. We can (and should) use the aggregation framework to construct our ETL pipeline and resort to MapReduce for the parts that are not yet supported sufficiently by it.

A complete use case with aggregation and MapReduce is provided in Chapter 5, Aggregation.

主站蜘蛛池模板: 甘孜县| 万全县| 阳东县| 临猗县| 邳州市| 石首市| 泗洪县| 华宁县| 滨州市| 土默特左旗| 嵊泗县| 塘沽区| 高州市| 武邑县| 墨竹工卡县| 蚌埠市| 加查县| 瓦房店市| 罗定市| 开平市| 石景山区| 兰西县| 宜黄县| 巴南区| 黄平县| 洛川县| 顺平县| 广宗县| 黑山县| 景德镇市| 万源市| 迭部县| 武胜县| 正阳县| 宜川县| 象州县| 南安市| 泗阳县| 吴桥县| 筠连县| 罗定市|