Всем привет. Nodejs, mongoose. Я совсем начинающий. Хочу сохранить в mongo изображение.

Для хранения фото в схеме определил тип поля 'Buffer'. Кстати, это я правильно сделал?
Дальше не могу найти материалов которые бы понятно объяснили что делать дальше и как сохранить в это поле изображение.
Подскажите, пожалуйста, что читать, куда копать или в целом принцип.
Что я должен сохранить в это поле?

Upd: файлы будут маленькие, GridFS не нужен. Как это сделать без Grid?

14 ответов

20 просмотров

Мой совет - GridFS + Multer

У монги есть ограничение по размеру документа, чтобы это избежать - нужно бить документ на чанки - для этого есть GridFS

NO WAR!- Автор вопроса
Anton Krevedko
Мой совет - GridFS + Multer

Насколько понял, Grid не нужен. Мои файлы точно не будут больше 16мб. Будут намного меньше. Забыл это написать. Сейчас поправлю вопрос. Это же наверняка можно сделать без Grid. Как?

NO WAR!- Автор вопроса
Anton Krevedko
Можно

Понял. Спасибо.

NO WAR!
Понял. Спасибо.

https://stackoverflow.com/a/52057719/12865136

NO WAR!- Автор вопроса
Anton Krevedko
https://stackoverflow.com/a/52057719/12865136

Спасибо. Этого не находил, хотя много что смотрел. Попробую.

есть ещё вариант хранить в монге ссылки, а сами файлы на стороннем сервисе. Например в s3

NO WAR!- Автор вопроса
Viktar
есть ещё вариант хранить в монге ссылки, а сами фа...

Думал об этом. Может так и сделаю позже. Сейчас хочу с хранением в mongo разобраться.

Viktar
есть ещё вариант хранить в монге ссылки, а сами фа...

вооо, щас как раз надо это реализовать

NO WAR!
Думал об этом. Может так и сделаю позже. Сейчас хо...

Сохранять файлы в базе не оч хорошая идея ИМХО, мы отказались в пользу s3. С файлами в базе (под 2терабайта картинок) maintenance был затруднён. Инишиал синк нового мембера реплики вообще не проходил.

NO WAR!- Автор вопроса
Anton Krevedko
https://stackoverflow.com/a/52057719/12865136

Антон, спасибо. 🤝 Все работает. 🎉 Записываю, потом могу из этой записи сделать файл. Еще раз спасибо.

NO WAR!- Автор вопроса
Andrew Khalin
Сохранять файлы в базе не оч хорошая идея ИМХО, м...

Полностью с вами согласен. Я сейчас реализую вариант с хранением в Монго в первую очередь для того, чтобы научиться и понять. Позже наверное попробую 2-й вариант. Но пока у меня и так сработает. У меня изображений будет немного и они все будут маленькие.

Похожие вопросы

Обсуждают сегодня

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
1. https://www.kaggle.com/code/ahmadrezagholami2001/housing-estimation-linear-regression 2. https://www.kaggle.com/code/ahmadrezagholami2001/uncovering-quality-in-wines-logis...
Ahmadreza
1
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Карта сайта