mirror of
https://github.com/Alex-Rachel/TEngine.git
synced 2025-08-14 16:51:28 +00:00
[+] 接入ET8服务端
[+] 接入ET8服务端
This commit is contained in:
@@ -0,0 +1,64 @@
|
||||
using System;
|
||||
|
||||
namespace ET.Client
|
||||
{
|
||||
[EntitySystemOf(typeof(PingComponent))]
|
||||
public static partial class PingComponentSystem
|
||||
{
|
||||
[EntitySystem]
|
||||
private static void Awake(this PingComponent self)
|
||||
{
|
||||
self.PingAsync().Coroutine();
|
||||
}
|
||||
|
||||
[EntitySystem]
|
||||
private static void Destroy(this PingComponent self)
|
||||
{
|
||||
self.Ping = default;
|
||||
}
|
||||
|
||||
private static async ETTask PingAsync(this PingComponent self)
|
||||
{
|
||||
Session session = self.GetParent<Session>();
|
||||
long instanceId = self.InstanceId;
|
||||
Fiber fiber = self.Fiber();
|
||||
|
||||
while (true)
|
||||
{
|
||||
if (self.InstanceId != instanceId)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
long time1 = self.Fiber().TimeInfo.ClientNow();
|
||||
try
|
||||
{
|
||||
C2G_Ping c2GPing = C2G_Ping.Create(true);
|
||||
using G2C_Ping response = await session.Call(c2GPing) as G2C_Ping;
|
||||
|
||||
if (self.InstanceId != instanceId)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
long time2 = self.Fiber().TimeInfo.ClientNow();
|
||||
self.Ping = time2 - time1;
|
||||
|
||||
fiber.TimeInfo.ServerMinusClientTime = response.Time + (time2 - time1) / 2 - time2;
|
||||
|
||||
await fiber.TimerComponent.WaitAsync(2000);
|
||||
}
|
||||
catch (RpcException e)
|
||||
{
|
||||
// session断开导致ping rpc报错,记录一下即可,不需要打成error
|
||||
Log.Info($"ping error: {self.Id} {e.Error}");
|
||||
return;
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
Log.Error($"ping error: \n{e}");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user