пришел к следующему решению. Можно создать мапу, где мы регистрируем каждое соединение по id(uint64). После этого вместе с коннектом создаем буффер для сообщений и bool переменную (назовем её 'x'). Создадим глобальный канал - очередь для сообщений, из которой читает несколько воркеров.
Когда хотим отправить сообщение - добавляем в буффер наши данные и проверяем 'x' (индикатор того - в очереди или нет) - если true, ничего не делаем, в другом случае добавяем в очередь на отправку. В воркерах флашим весь буффер и обнуляем х.
Тогда можно на каждого клиента запускать только одну горутину (или вообще 0, если использовать еполл у тп). Я не уверен в том будет ли это работать или нет, но может есть готовые решения или хотя бы концепты чего-то подобного?
https://habr.com/ru/company/mailru/blog/331784/
очень вредная статья
ваша про каналы не лучше)
я в го новенький совсем а можно узнать почему? мне показалось интересной
это которая
Обсуждают сегодня