5

I updated our signalr packages from 2.4.0 and added RunAzureSignalR instead of RunSignalR. Added this code in de Startup.cs

app.Map("/signalr", map =>
{
    var hubConfiguration = new HubConfiguration
    {
        EnableDetailedErrors = true
    };

    map.RunAzureSignalR(typeof(Startup).FullName, hubConfiguration, options =>
    {
        options.ConnectionString = AppApiSettings.SignalRServiceConnectionString;
    });
});

But when I try to send a message to the hub I get an exception The connection is not active, data cannot be sent to the service.. Can't find any reason this would happen or why the service would not run.

When I use RunSignalR (self hosted) everything runs great.

Any help would be greatly appreciated.

Youp Hulsebos
  • 166
  • 1
  • 9

1 Answers1

2

It turns out Azure Service only support TLS1.2 for security concerns. Please add following code to your Startup:

ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;

The hint for this solution was found on a github ticket: https://github.com/Azure/azure-signalr/issues/279

"No server available" indicates that your app server has trouble connecting to Azure service. You can enable tracing from the app server side with the following to see if any error throws.

GlobalHost.TraceManager.Switch.Level = SourceLevels.Information;

A sample here: https://github.com/Azure/azure-signalr/blob/dev/samples/AspNet.ChatSample/AspNet.ChatSample.SelfHostServer/Startup.cs#L19

If you are local debugging the server side, you can also uncheck "Just My Code" and break when any CLR exception throws:

Disable just my code enter image description here System.Security.Authentication.AuthenticationException: "A call to SSPI failed, see inner exception." - (inner) "The function requested is not supported"

System.ObjectDisposedException: 'Safe handle has been closed'

System.Net.WebException: 'The request was aborted: Could not create SSL/TLS secure channel.'

System.Net.WebSockets.WebSocketException: 'Unable to connect to the remote server' - (inner) WebException: The request was aborted: Could not create SSL/TLS secure channel.

Youp Hulsebos
  • 166
  • 1
  • 9