RouterCheckComponentSystem.cs 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. using System;
  2. using System.Net;
  3. namespace ET.Client
  4. {
  5. [ObjectSystem]
  6. public class RouterCheckComponentAwakeSystem: AwakeSystem<RouterCheckComponent>
  7. {
  8. protected override void Awake(RouterCheckComponent self)
  9. {
  10. CheckAsync(self).Coroutine();
  11. }
  12. private static async ETTask CheckAsync(RouterCheckComponent self)
  13. {
  14. Session session = self.GetParent<Session>();
  15. long instanceId = self.InstanceId;
  16. while (true)
  17. {
  18. if (self.InstanceId != instanceId)
  19. {
  20. return;
  21. }
  22. await TimerComponent.Instance.WaitAsync(1000);
  23. if (self.InstanceId != instanceId)
  24. {
  25. return;
  26. }
  27. long time = TimeHelper.ClientFrameTime();
  28. if (time - session.LastRecvTime < 7 * 1000)
  29. {
  30. continue;
  31. }
  32. try
  33. {
  34. long sessionId = session.Id;
  35. (uint localConn, uint remoteConn) = await NetServices.Instance.GetChannelConn(session.ServiceId, sessionId);
  36. IPEndPoint realAddress = self.GetParent<Session>().RemoteAddress;
  37. Log.Info($"get recvLocalConn start: {self.ClientScene().Id} {realAddress} {localConn} {remoteConn}");
  38. (uint recvLocalConn, IPEndPoint routerAddress) = await RouterHelper.GetRouterAddress(self.ClientScene(), realAddress, localConn, remoteConn);
  39. if (recvLocalConn == 0)
  40. {
  41. Log.Error($"get recvLocalConn fail: {self.ClientScene().Id} {routerAddress} {realAddress} {localConn} {remoteConn}");
  42. continue;
  43. }
  44. Log.Info($"get recvLocalConn ok: {self.ClientScene().Id} {routerAddress} {realAddress} {recvLocalConn} {localConn} {remoteConn}");
  45. session.LastRecvTime = TimeHelper.ClientNow();
  46. NetServices.Instance.ChangeAddress(session.ServiceId, sessionId, routerAddress);
  47. }
  48. catch (Exception e)
  49. {
  50. Log.Error(e);
  51. }
  52. }
  53. }
  54. }
  55. }