- Mastering MongoDB 3.x
- Alex Giamas
- 325字
- 2021-08-20 10:10:57
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.
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.
- Mastering Mesos
- 計算機應(yīng)用
- Mastering Hadoop 3
- Natural Language Processing Fundamentals
- 21天學(xué)通C#
- JSF2和RichFaces4使用指南
- 21天學(xué)通Visual C++
- CompTIA Network+ Certification Guide
- ESP8266 Home Automation Projects
- 電腦日常使用與維護(hù)322問
- 電腦上網(wǎng)輕松入門
- SMS 2003部署與操作深入指南
- Flink原理與實踐
- 嵌入式GUI開發(fā)設(shè)計
- WOW!Photoshop CS6完全自學(xué)寶典