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

Всем привет. Пишу свой сервер для вебсокетов. Хочу запустить два

инстанса сервера, для этого нужен брокер - redis, kafka, rabbit. Теперь, осталось понять как лучше балансировать нагрузку, через nginx или haproxy не получится. Мне кажется, что довольно удобно было бы сделать отдельный dns сервер, который бы подключался к брокеру и через него собирал инфу о доступных инстансах (либо ws-сервер сам уведомляет о себе, либо ping с каким-то интервалом) и раздавать ip сервер раунд-робином. Есть ли какие-то готовые решения на замену вышеописанной техники?

8 ответов

6 просмотров

почему через nginx не получится? он же вроде умеет в least connections

haproxy с first, мы так и живем кстати

Почему брокер нужен обязательно?

Roman-Ischenko Автор вопроса
Zver
Почему брокер нужен обязательно?

ну, мне кажется, это удобно - ты отправляешь сообщение, допустим в чат, пользователи чата на разных серверах, а брокер обеспечивает доставку на все сервера

Roman-Ischenko Автор вопроса
Zver
Почему брокер нужен обязательно?

ну или на сервера подписанные на сообщения из чата

Ну вы всегда можете сделать тупой балансировщик - сначало спросить у одного простенького балансировщика, который следит за жизнью ваших инстансов и их нагрузкой, куда присоединяться сокетом, и клиентом уже напряму присоединяетесь к конкретному инстансу 😄

Roman-Ischenko Автор вопроса

вообще, попахивает ipvs dsr или вообще katran

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

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

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
13
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Ошибка: segmentation fault (core dumped) Код: pastebin.com/BEsNNSSV Сообщение от компилятора: отсутствует ОС: Arch Linux Ядро: x86_64 Linux 6.9.7-arch1-1 Процессор: Intel Cele...
sec
4
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Карта сайта