Możesz zapytać o wszystkie uruchomione zadania za pomocą db.currentOp().
Zwykle zadanie Map/Reduce ma kilka atrybutów, o które można zapytać.
Zlecenie M/R, które właśnie wykonałem, miało następujące statystyki:
"opid" : 258101377,
"active" : true,
"secs_running" : 4638,
"op" : "query",
"ns" : "<database>.<collectionname>",
"query": {
"mapreduce": "<collectionname>",
"map": function <randomname>() { ... },
"reduce": function <randomname>(k, v) { ... },
"out": { ... }
}
"msg": "m/r: (1/3) emit phase 1235099/11558528 10%",
"progress" : {
"done" : 1235099,
"total" : 11558528
},
...
Właśnie tego powinieneś szukać! Zwłaszcza atrybut „msg”, który mówi o postępach M/R.