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

  • 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.

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.

主站蜘蛛池模板: 民和| 民乐县| 翼城县| 扶绥县| 务川| 金阳县| 成都市| 临夏县| 新野县| 香河县| 威海市| 于田县| 五大连池市| 思南县| 兰西县| 沙洋县| 筠连县| 太湖县| 自治县| 华亭县| 凤翔县| 开鲁县| 谢通门县| 朔州市| 乳源| 化隆| 神木县| 毕节市| 罗源县| 泾源县| 阳朔县| 大悟县| 玉田县| 曲松县| 自治县| 太康县| 通榆县| 会昌县| 广河县| 安徽省| 花莲县|