170 похожих чатов

Доброй ночи. Проект с монгодб, появилась недобность апдейтить раз в

10 минут поле в документах коллекции.
Увы, монга не умеет так делать (если это как-то возможно вдруг, то напишите обязательно).

Решили с проблемой разобраться с помощью планировщика, работающего в воркере. Который бы раз в 10мин проходил по нужным документам и менял поле.

1) как на ваш взгляд, это решение, вообще, адекватное?

2) если есть у вас варианты альтернативного решения лучше, то напишите,пож. (хотя бы в паре слов)

3) В проекте много вебсокетов и общения с mqtt брокером. Требуется максимально не блокировать поток. PostgreSQL может подойти для такого проекта?

Переход с монго на postgre затруднителен быстро, но, по крайне мере, такая задача в sql движке решается не программно через нодовский планировщик, а настроенным ttl

4 ответов

12 просмотров

Я бы вынес часто изменяющиеся данные в другую коллекцию, а то и вообще куда-нибудь в редис. В постгресе апдейтить отдельные поля проще, но это версионник, а значит, на каждый апдейт он будет сохранять новую копию записи, и база будет пухнуть, так что нужно будет делать вакуум, а это дополнительные нагрузки. Впрочем, я несколько лет серьёзно не занимался бэкендом, может, с тех пор что-то изменилось.

я микросервис писал для микрозсдачи для монго

Если это независимые от основного процесса действия, и если нагрузки на основной процесс вообще большие, то вы этим воркером один слот в thread pool'е как минимум займете и что за планировщик? Почему нельзя просто отдельный процесс пускать по крону, который никому мешать не будет и который точно раз в 10 минут будет запускаться?

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

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

Сообщение* в закодированном виде. То есть, просто сделать sendMessage?text=Привет бла-бла! не получится, надо в HEX переводить, и добавлять процент, типа такого: sendMessage?t...
КТ315
21
А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
Хм. А телеграм апи работают через HTTP?
The Bird of Hermes
14
Почему Telegram пишет, что объект media не найден, хотя на самом деле я его передаю? Делаю на urllib, без зависимостей, так надо. Вызываю метод sendMediaGroup с таким JSON: ...
Alexey S
1
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Я тут за тем, чтобы задать вопрос, так как не знаю ассемблер, учу с/с++. Короче, насколько дорога операция перехода в функцию при ее вызове? Дело в том, что в с++ есть макросы...
Максим Рябцев
12
Привет, нужен совет старших товарищей. Есть глобальная переменная var DefaultDataFolder:string; инициализируем DefaultDataFolder:='a:\_OUT\'; есть примитивная процедур...
Max Otto
14
А какие чаты вообще в ходу? Auto aim? И что еше
do you think you're better off alone? А
13
hello friends. Do you know how can I learn getx? I have a software project that I should deliver it up to 5 weeks later and I need to learn firebase too. I will be thankfull
AmirHossein Razavi
15
Карта сайта