#heroku #multer #gridfs #storage-engines
#heroku #мультер #gridfs #механизмы хранения
Вопрос:
Когда я пытаюсь развернуть свое приложение в Heroku, я получаю сообщение об ошибке «Ошибка создания механизма хранения. Должен быть указан хотя бы один из параметров url или db «. в моих журналах heroku. Тем не менее, я не получаю ошибок при разработке и тестировании приложения в моей IDE.
Вот мой журнал ошибок:
...
2020-10-17T05:24:18.106601 00:00 app[web.1]: Error: Error creating storage engine. At least one of url or db option must be provided.
2020-10-17T05:24:18.106602 00:00 app[web.1]: at new GridFSStorage (/app/node_modules/multer-gridfs-storage/lib/gridfs.js:59:10)
2020-10-17T05:24:18.106602 00:00 app[web.1]: at Object.<anonymous> (/app/config/multer.js:7:17)
2020-10-17T05:24:18.106603 00:00 app[web.1]: at Module._compile (internal/modules/cjs/loader.js:1015:30)
2020-10-17T05:24:18.106604 00:00 app[web.1]: at Object.Module._extensions..js (internal/modules/cjs/loader.js:1035:10)
2020-10-17T05:24:18.106604 00:00 app[web.1]: at Module.load (internal/modules/cjs/loader.js:879:32)
2020-10-17T05:24:18.106605 00:00 app[web.1]: at Function.Module._load (internal/modules/cjs/loader.js:724:14)
2020-10-17T05:24:18.106605 00:00 app[web.1]: at Module.require (internal/modules/cjs/loader.js:903:19)
2020-10-17T05:24:18.106605 00:00 app[web.1]: at require (internal/modules/cjs/helpers.js:74:18)
2020-10-17T05:24:18.106606 00:00 app[web.1]: at Object.<anonymous> (/app/server.js:9:16)
2020-10-17T05:24:18.106607 00:00 app[web.1]: at Module._compile (internal/modules/cjs/loader.js:1015:30)
...
Вот мой код для multer:
require('dotenv').config();
const path = require('path');
const crypto = require('crypto');
const multer = require('multer');
const GridFsStorage = require('multer-gridfs-storage');
const storage = new GridFsStorage({
url: process.env.URI,
options: { useUnifiedTopology: true },
file: (req, file) => {
return new Promise((resolve, reject) => {
crypto.randomBytes(16, async (err, buf) => {
if (err) return reject(err);
const filename = buf.toString('hex') path.extname(file.originalname);
const fileInfo = { filename, bucketName: 'uploads' };
resolve(fileInfo);
});
});
}
});
const upload = multer({ storage });
module.exports = upload;
Моя process.env.URI
переменная имеет вид: URI=mongodb srv://...
Любая помощь приветствуется 🙂
Ответ №1:
Я обнаружил, что ошибка на самом деле связана с моими переменными среды. Мне пришлось настроить их в Heroku, чтобы приложение могло их прочитать (я полагался на свой .env
файл, но, конечно .gitignore
, файл не позволит передать файл в Heroku master).