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

Здравствуйте. Есть структура pubsub. В ней содержатся данные о клиентах

и топиках(один клиент может быть во многих топиках). Хранятся вышеописанные данные в мапах под rwmutex'ом. Это лок огранияивает пропускную способность, что мне не нравится. Подумал, что можно шардировать клиентов по их айдишникам, но при такой системе приходиться хранить данные о том к какому шарду какик топики привязаны, что замедляет процесс распределения (к примеру нам поступает запрос - отправить сообщение клиентам: 1, 2 и в топики: chat1, chat2, мы находим по хэшу id клиентов их шарды, а шарды топиков по встроенному map'у с адрессами). Есть какие-то более подходящие алгоритмы распределения для млей ситуации?

4 ответов

7 просмотров

не совсем понятно как хранятся данные сейчас

Roman-Ischenko Автор вопроса
Алтынбек Шарипов
не совсем понятно как хранятся данные сейчас

map[string]*client - клиенты map[string]map[*client]struct{} - топики

А чего не сделать мапу в которой ключ - client_id, а значение - список топиков?

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

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

А чем вам питонисты не угодили?😂
.
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
8
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
Карта сайта