Проблемы с рукопожатием SignalR после перехода на сервер AWS за балансировщиком нагрузки приложения - PullRequest
0 голосов
/ 28 мая 2020

Проблемы с рукопожатием SignalR после перехода на AWS за балансировщиком нагрузки приложения.

Раньше я запускал его на экземпляре EC2 с nginx, который работал нормально после этого совета; Вход SignalR ASP. NET Сердечник позади Nginx. Но из-за этого нам пришлось переместить его на AWS fargate и использовать Aws Application Load balancer (ALB). Теперь мы не можем запустить signalR. У службы есть REST api, который работает нормально.

И я все еще могу переключиться обратно на старую инфраструктуру, и это работает как шарм.

Из приложения flutter я получаю следующее:

flutter: [Signals] Connection Restarting after http error - 404 - Not Found
flutter: [Signals] Connection Closed - Cannot start a connection that is not in the 'Disconnected' state.
flutter: [Signals] [Transport] SEVERE: : Server returned handshake error: 'Handshake was canceled.'
flutter: [Signals] [Hub] SEVERE:  Server returned handshake error: 'Handshake was canceled.'
[VERBOSE-2:ui_dart_state.cc(157)] Unhandled Exception: type 'GeneralError' is not a subtype of type 'Error'
0      ServerSentEventsTransport.connect.<anonymous closure> 
package:signalr_client/server_sent_events_transport.dart:73
1      _rootRunUnary  (dart:async/zone.dart:1192:38)
2      _CustomZone.runUnary  (dart:async/zone.dart:1085:19)
3      _CustomZone.runUnaryGuarded  (dart:async/zone.dart:987:7)
4      _BufferingStreamSubscription._sendData  (dart:async/stream_impl.dart:339:11)
5      _DelayedData.perform  (dart:async/stream_impl.dart:594:14)
6      _StreamImplEvents.handleNext  (dart:async/stream_impl.dart:710:11)
7      _PendingEvents.schedule.<anonymous closure>  (dart:async/stream_impl.dart:670:7)
8      _rootRun  (dart:async/zone.dart:1180:38)
9      _CustomZone.run  (dart:async/zone.dart:1077:19)
10     _CustomZone.runGuarded  (dart:async/zone.dart:979:7)
11     _CustomZone.bindCallbackGuarded.<anonymous closure>  (dart:async/zone.dart:1019:23)
12     _rootRun (dart:async/zone.da<…>
[VERBOSE-2:ui_dart_state.cc(157)] Unhandled Exception: Server returned handshake error: 'Handshake was canceled.'
flutter: [Signals] [Transport] SEVERE:Connection disconnected with error 'Server returned handshake error: 'Handshake was canceled.''.
flutter: [Signals] [Hub] SEVERE: Connection disconnected with error 'Server returned handshake error: 'Handshake was canceled.''.
flutter: [Signals] Connection Closed - Server returned handshake error: 'Handshake was canceled.'

И это:

flutter: [Signals] [Transport] SEVERE: 2020-05-28 14:10:11.870554: Failed to start the transport 'HttpTransportType.WebSockets': WebSocketException: Connection to 'https://api.com:0/hubs/people?id=[id]&access_token=[Token] was not upgraded to websocket

Это похоже на проблему, которую мы решили в nginx, но я подумал, что AWS ALB должен обрабатывать ее по умолчанию. Если я запускаю службу локально, она работает нормально.

Мы используем:

  • Flutter с этим клиентом signalR: https://github.com/soernt/signalr_client
  • API: TargetFramework:
  • netcoreapp2 .1 Docker: mcr.microsoft.com/dotnet/core/aspnet:2.1-alpine
  • Microsoft.AspNetCore.SignalR.Protocols.MessagePack: 1.0.0

Заранее спасибо

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...