SessionIdleCheckerComponentSystem.cs 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. using System;
  2. namespace ET
  3. {
  4. [Invoke(TimerInvokeType.SessionIdleChecker)]
  5. public class SessionIdleChecker: ATimer<SessionIdleCheckerComponent>
  6. {
  7. protected override void Run(SessionIdleCheckerComponent self)
  8. {
  9. try
  10. {
  11. self.Check();
  12. }
  13. catch (Exception e)
  14. {
  15. Log.Error($"move timer error: {self.Id}\n{e}");
  16. }
  17. }
  18. }
  19. [ObjectSystem]
  20. public class SessionIdleCheckerComponentAwakeSystem: AwakeSystem<SessionIdleCheckerComponent>
  21. {
  22. protected override void Awake(SessionIdleCheckerComponent self)
  23. {
  24. self.RepeatedTimer = TimerComponent.Instance.NewRepeatedTimer(ConstValue.SessionTimeoutTime / 2 + 100, TimerInvokeType.SessionIdleChecker, self);
  25. }
  26. }
  27. [ObjectSystem]
  28. public class SessionIdleCheckerComponentDestroySystem: DestroySystem<SessionIdleCheckerComponent>
  29. {
  30. protected override void Destroy(SessionIdleCheckerComponent self)
  31. {
  32. TimerComponent.Instance?.Remove(ref self.RepeatedTimer);
  33. }
  34. }
  35. public static class SessionIdleCheckerComponentSystem
  36. {
  37. public static void Check(this SessionIdleCheckerComponent self)
  38. {
  39. Session session = self.GetParent<Session>();
  40. long timeNow = TimeHelper.ClientNow();
  41. if (timeNow - session.LastRecvTime < ConstValue.SessionTimeoutTime && timeNow - session.LastSendTime < ConstValue.SessionTimeoutTime)
  42. {
  43. return;
  44. }
  45. Log.Info($"session timeout: {session.Id} {timeNow} {session.LastRecvTime} {session.LastSendTime} {timeNow - session.LastRecvTime} {timeNow - session.LastSendTime}");
  46. session.Error = ErrorCore.ERR_SessionSendOrRecvTimeout;
  47. session.Dispose();
  48. }
  49. }
  50. }