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

Какой стек лучше всего использовать для websocket чата ( в

перспективе будет млн + конекшенов) Soket.IO https://socket.io/docs/v4/redis-adapter/ - нормально масштабируется горизонтально ,пробовал кто или лучше свое что-то мастерить с своим брокером для такой задачи? Читал что RabbitMQ/Kafka не очень будут подходить для такой задачи с таким количеством сообщением

3 ответов

27 просмотров

> During the peak hours, the number of concurrent users on the site is in several million Это про фейсбук. Неопытные заказчики любят раздувать цифры по нагрузке, не понимая стоимости таких работ.

Вот нашел хороший пример архитектуры https://scaleyourapp.com/facebook-real-time-chat-architecture-scaling-with-over-multi-billion-messages-daily/ Вкратце - достаточно любой реляционной СУБД для хранения хистори по чату и любого MQ для доставки обновлений.

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Карта сайта