0
votes

We are trying to scale out our environment. I was using a ConnectionMapper class like the one here: http://www.asp.net/signalr/overview/guide-to-the-api/mapping-users-to-connections to keep a list of connections.

How would I make this work in a cluster (2 nodes)? would I implement a backplane? http://www.asp.net/signalr/overview/performance/scaleout-in-signalr

And then move the connection mappings to SQL DB?

This is for an MVC application.

1
Do you mean backplane?hometoast
yes. Backplane. Also, Not sure "Backplane" and Connections relate. Or they don't at all. I would still use the same ConnectionMapper class and backplate would know which User to send the message to?ShaneKm

1 Answers

1
votes

Hmm you couldn't use something like the Connection Mapper with a backplane. The problem with in-memory mapping like that is that you wouldn't be able to communicate between the nodes without using your database table but that would also be painful (a lookup in the db for each message sent?).

You would do better by using groups (i.e. adding each user from the company ABC to the "ABC" group - or perhaps use a unique id such as companyId from a database table. Once you've got it using groups on one node then you can start using a backplane...

Groups docs: http://www.asp.net/signalr/overview/guide-to-the-api/working-with-groups

But then again there are issues with using a backplane - i.e. what do you hope to achieve using a backplane? Take a look at what SignalR describe as the limitations of using a backplane in http://www.asp.net/signalr/overview/performance/scaleout-in-signalr . Backplane scaleout is a pain as there is a good chance it may have a lower message throughput and higher latency than a single node schenario... In the example of a game - you might be better off having each node being completely independent and guiding users to the correct node (so node A hosts games 1 - 8, and node B hosts games 9 - 16)