Всем доброго вечера Разрабатываем чат-приложение с кастомными видами сообщений (разные типы/подтипы,

разные уровни доступа к сообщениям).
Уже сейчас насчитывается 6 различных паттернов доступа к истории, плюс есть еще вероятность, что их количество увеличится в двое.
Плюс сервис должен будет выдерживать пиковую нагрузку в 10к на начальном этапе, в перспективе больше.
Подскажите, какие сервисы стоит рассматривать в качестве хранилища истории сообщений для такой задачи?
Пока рассматриваем аврору, динамо, рдс + ручное поднятие монги или кассандры в екс.
От документ-дб и кей-спейсес пока что отказались, так как непонятен уровень совместимости с монгой/кассандрой.

10 ответов

15 просмотров

Глянуть в сторну Pulsar может,

А как именно вы рассматриваете ?

А какие требования к latency? Плюс 10к запросов - наверное кешировать многое можно?

Azamat-Zhurtbayev Автор вопроса
Nikolay
А как именно вы рассматриваете ?

В первую очередь решение должно выдержать 10к рпс. Должна быть возможность скейлить решение вверх. Плюс стоимость решение - тут будет полезно скейлиться вниз, когда нет нагрузки.

Azamat-Zhurtbayev Автор вопроса
Al T
А какие требования к latency? Плюс 10к запросов - ...

По лэтенси не критично, но до секунды это нормально. 10к в контексте чатов - это только новые сообщения (вставки).

Azamat Zhurtbayev
В первую очередь решение должно выдержать 10к рпс....

Если 10 к на чтение ,то выдержит любая база. Если это на запись , то реляционка потянет только на ssd, если вы планируете делать commit после каждой вставки .т.е это скорее будет предел для Авроры,postgre,mysql И в дальнейшем вам нужно будет делать шардирование и разносить чаты по разным инстансам. Т.е у вас будет много инстансов mysql, например и вы будите в приложении или где -то ещё делать роутинг на нужный инсианс. Ну или взять диманодб.

Azamat-Zhurtbayev Автор вопроса
Nikolay
Если 10 к на чтение ,то выдержит любая база. Если...

10к - подразумевается на запись (делаем чаты, и там чтение происходит намного реже, чем запись). да, коммит после каждой вставки. по поводу ограничения спасибо, будем иметь в виду. новые сообщения будут пересылаться через message-broker + websockets. чтение будет происходить для подгрузки исторических сообщений.

Azamat Zhurtbayev
По лэтенси не критично, но до секунды это нормальн...

ну вы там написали еще и коммит (fsync?) после каждой вставки, это прям сурово для чатика... RDBMS с single master масштабируется шардированием (после невозможности scale up) но это удовольствие то ещё )) Возможно Динамо и ваш вариант, вы там писали что на каждый паттерн нужен отдельный индекс но это далеко не всегда так..

Azamat-Zhurtbayev Автор вопроса
Al T
ну вы там написали еще и коммит (fsync?) после ка...

а что такого в коммите после каждого сообщения, если цель не потерять ниодного сообщения?

Azamat Zhurtbayev
а что такого в коммите после каждого сообщения, ес...

Да ничего собственно, просто просадка по производительности по сравнению с фсинк каждую секунду. Дешевле параллельно хранить последние 5 минут в редисе или очереди. Я наверно вообще в базу не писал напрямую сразу а в кинесис или кафку. А сообщения передавал через паб саб

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

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

Всем привет. Нужна платная консультация от тех, кто сталкивался с октябрём в кластере или шарит оч хорошо в цмс. Проблема следующая: после переноса в кластер октябрь начал ...
wl
8
Добрый день, не подскажите, если в OC-V3 поменять страндартную директорию /storage/ на /storage2/ - не будет сильно много проблем ?
Max Dubovsky
32
'frakturBold' => ['𝖆', '𝖇', '𝖈', '𝖉', '𝖊', '𝖋', '𝖌', '𝖍', '𝖎', '𝖏', '𝖐', '𝖑', '𝖒', '𝖓', '𝖔', '𝖕', '𝖖', '𝖗', '𝖘', '𝖙', '𝖚', '𝖛', '𝖜', '𝖝', '𝖞', '𝖟', '𝕬', '𝕭', '𝕮', '𝕯'...
Roma
4
а я честно сказать не понимаю - нахуя идти учиться на вышку или еще куда-либо и при этом нихуя не делать, типа зачем ? просто корку получить, а нахуй она нужна тогда ?
Eugene Неелов
7
Каким то образом можно определить ширину экрана пользователя перед загрузкой partial-а? Надо рассчитать ширину кадров слайдера для ресайза картинок для container-fluid.
Point 111
22
А сколько часов мак держит зарядку в рабочем режиме? Например мой Redmi Mac (просто наклейка от айфона осталась, налепил) по началу держал часов 5 с парой открытых штормов и ...
Ross
8
зараз якщо створити файл core/custom/define.php з текстом <?php const NO_SESSION = true; можна позбутися сесійних кукі (що зручно, щоб не показувати людям банери про збір та в...
Artur Kyryliuk
1
я бы даже сказал не размер резюме, а слова, которые там написаны, потому что резюме может быть на несколько десятков страниц из-за 20 летнего опыта работы, но там в опыте буде...
Eugene Неелов
2
так а я не могу просто новый сделать ? я пробовал не прокатило но может чето упускаю
Максим
3
Ребят, было ли у вас так, что переменные в WebApp —tg-viewport-height, —tg-viewport-stable-height после метода expand не обновляются, а остаются в размерах, как было до expand...
Black
3
Карта сайта