Каждый запрос, использующий JS, может повторно использовать или получить новый контекст JS, в который загружаются сохраненные объекты JS.
Для того, чтобы делать то, что вы хотите, вам нужно:
- mongod для автоматического запуска сохраненного кода при его установке
- mapreduce для использования метода init
Первая, безусловно, более интересная функция.
Оказывается, сборка mongodb v8 делает это автоматически (но официально не поддерживается), но не официальная сборка spidermonkey.
Скажем, вы храните код как:
db.system.js.save({ _id: "mylib", value: "myprint = function() { print('installed'); return 'installed';" }
Тогда в v8 вы можете свободно использовать myprint () в своем коде, но для SM вам придется явно вызывать mylib ().
В качестве обходного пути вы можете создать другой метод:
db.system.js.save({ _id: "installLib", value: "if (!libLoaded) mylib(); libLoaded = true;" }
И вызовите его из функции map ().
Создан тикет для стандартизации двигателей и автоматического запуска:
https://jira.mongodb.org/browse/SERVER-4450