I'm trying out the latest SignalR on ASP.NET Core 2.1. I have the basic app working but it times out pretty soon right now. I see this error -
Error: Connection disconnected with error 'Error: Server timeout elapsed without receiving a message from the server.'.
Where can this timeout setting be changed? I tried the docs here but no info about timeout there. I'm running on a dev environment of Windows 10 and using JavaScript client.
Edit: Inserting image after enabling client logging.
Edit 2: Link to page containing timeouts about the older SignalR version.
For people that may come here in future:
Here is how to increase Javascript client timeout
hubConnection.serverTimeoutInMilliseconds = 100000; // 100 second
But also take a look at this link and then read my comments below:
If signalR got disconnected, you should try re-establishing the connection again. The connection could drop for several other reasons, including the user switching networks. For example if the user is using a cell-phone and connected to the home/office wifi but steps out which then connects to cellular data connection.
To reconnect you could use the following (works like a charm for me):
// re-establish the connection if connection dropped
connection.onclose(() => setTimeout(startSignalRConnection(connection), 5000));
where startSignalRConnection
is :
const startSignalRConnection = connection => connection.start()
.then(() => console.info('Websocket Connection Established'))
.catch(err => console.error('SignalR Connection Error: ', err));
and connection is
const connection = new HubConnectionBuilder()
.withUrl(connectionHub, options)
.withHubProtocol(protocol)
.build();