2016-05-31 6 views
1

Предположим, у меня есть два концентратора в моем приложении SignalR. Я сопоставляю connectionIds -> userIds в локальном кеш-словаре.SignalR: Может ли событие OnDissconnect концентратора вызываться только для конкретного концентратора?

Текущая логика примерно так:

С OnConnected -> добавить новую запись «ConnectionID в USERID» в словаре (если он не существует).

С OnDisconnected -> удалить, что «ConnectionID в USERID» запись из словаря (если он существует)

Есть ли сценарий, который HUB1 будет отключен во время Hub2 будет оставаться на связи?

Если это так, моя текущая логика ошибочна, поскольку она удалит запись из словаря, хотя Hub2 все еще подключен. который потребует от меня обработки 2 словарей для каждого концентратора.

P.S. Я просмотрел документы SignalR для обработки сопоставлений соединений, и всегда кажется, что они используют один словарь для одного концентратора. поэтому я хочу знать, действительно ли это необходимо.

+1

Привет Офир. Просто предложение, вы можете изучить использование однопользовательских групп, чтобы сохранить это сопоставление. Это проще реализовать, и вам не нужно подчеркивать, что вы поддерживаете словарь. Проверьте [это] (http://stackoverflow.com/questions/37455608/handling-concurrent-connections-in-siganlr/37458129#37458129) –

+0

Очень элегантное решение! Думаю, я пойду по этому пути. спасибо – Ofir

ответ

1

Согласно документации Signalr совместно используют одно соединение для нескольких концентраторов. Поэтому, если вы получаете вызов OnDisconnect, все концентраторы должны быть отключены.

SignalR 2.0 был обновлен, чтобы обрабатывать несколько концентраторов над одним сигнальным сигналом соединение без потери производительности.

http://www.asp.net/signalr/overview/guide-to-the-api/hubs-api-guide-server#multiplehubs

+0

Вы правы, я просмотрел код класса HubDispatcher, функция получает все хабы и выполняет событие разъединения на всех подключенных концентраторах. – Ofir