You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
A socket on unix doesn't support reconnecting with the same file descriptor after a failed connection. This has created an issue for the .NET Socket design, whereby options can be set onto a Socket instance, and then that Socket instance can be connected to something that might actually require multiple attempts. To make this work, the Socket tracks known settings, and recreates the file descriptor under the covers upon a failed attempt. If an unknown setting is used, Socket refuses to connect to an endpoint that might possibly require multiple attempts, e.g. a DnsEndPoint. Unfortunately, we're not applying this consistently across such connect methods.
Unhandled exception. System.PlatformNotSupportedException: Sockets on this platform are invalid for use after a failed connection attempt.
at System.Net.Sockets.Socket.ThrowMultiConnectNotSupported()
at System.Net.Sockets.Socket.ConnectAsync(SocketAsyncEventArgs e, Boolean userSocket, Boolean saeaCancelable)
at System.Net.Sockets.Socket.AwaitableSocketAsyncEventArgs.ConnectAsync(Socket socket)
at System.Net.Sockets.Socket.ConnectAsync(EndPoint remoteEP, CancellationToken cancellationToken)
at System.Net.Sockets.Socket.ConnectAsync(EndPoint remoteEP)
at Program.<Main>$(String[] args)
completes successfully, even though they're logically the same, with the former just doing the DNS lookup and effectively then behaving as if that list was provided.
At this point, it'd likely be a significant breaking change to make the latter fail like the former.
We should reconsider the behavior for the former, and possibly revisit the whole retry mechanism, caching more aggressively such that few-to-no settings knock us off the golden path.
The text was updated successfully, but these errors were encountered:
A socket on unix doesn't support reconnecting with the same file descriptor after a failed connection. This has created an issue for the .NET Socket design, whereby options can be set onto a Socket instance, and then that Socket instance can be connected to something that might actually require multiple attempts. To make this work, the Socket tracks known settings, and recreates the file descriptor under the covers upon a failed attempt. If an unknown setting is used, Socket refuses to connect to an endpoint that might possibly require multiple attempts, e.g. a DnsEndPoint. Unfortunately, we're not applying this consistently across such connect methods.
This:
throws the exception:
But this:
completes successfully, even though they're logically the same, with the former just doing the DNS lookup and effectively then behaving as if that list was provided.
At this point, it'd likely be a significant breaking change to make the latter fail like the former.
We should reconsider the behavior for the former, and possibly revisit the whole retry mechanism, caching more aggressively such that few-to-no settings knock us off the golden path.
The text was updated successfully, but these errors were encountered: