记录一次Unity中的同步问题

发布时间:2022-04-01

在以前做的数字孪生应用中,使用的 socket 进行定制协议开发,服务和 Unity 客户端之间可以互相进行通信,在开发时代价太大,除了正常制定数据协议外,还需要针对粘包定制切包协议。在WEB化的过程中,准备把原有的数字孪生服务端进行迁移,使用全新的 asp.net core 进行开发,双方使用 signalR 进行数据交互。

应用结构说明

简要介绍一下应用结构,整个数字孪生应用主要分为四部分,数据采集部分,交互控制部分,数据分发部分,Unity前端部分。

运行起来就是这样的,采集服务会采集各设备运行数据,发送给分发服务,分发服务又根据配置把实时数据分发到各个客户端,客户端也可以发送命令给控制服务对设备进行控制。

问题

这里主要介绍分发的时候,在 unity 中使用导入 signalR 的包,注意,依赖包也需要一并导入,不然他会从自带的 mono 库里进行导入,如果你的项目刚好使用的是 .Net 4.x 配置,那对不起,项目根本通不过编译。如果是使用 .Net Standard ,那有一定的几率可以通过编译。

说回使用,根据文档写出如下代码,接收到服务推送的消息,然后通过 消息中心 转发到各个组件进行处理.

 HubConnection hub = new HubConnectionBuilder()
            .WithUrl("http://signalr-url")
            .WithAutomaticReconnect()
            .Build();

hub.On<string, List<SendPackage>>("channel", (user, msg) =>
{
      //使用消息中心进行进程内转发
      MessageCenter.Send(new { }, "channel", msg);
});

await hub.StartAsync();

这个代码在编辑器里调试运行得非常正常,除了有时候退出编辑器运行还在偷偷收消息以外。然后打包,发布,上线一通操作后,运行起来发现根本收不到消息,这时候查看服务日志发现根本就没有收到连接请求,尝试几次之后更加确认就是 unity 没有发送连接请求了。

解决

然后经过一顿瞎操作多次尝试切换参数之后,发现必须要指定协议类型为 websocket ,跳过token验证,这才可以正常通信。

修改后代码如下

 HubConnection hub = new HubConnectionBuilder()
            .WithUrl("http://signalr-url", 
                        HttpTransportType.WebSockets, 
                        x => x.SkipNegotiation = true)
            .WithAutomaticReconnect()
            .Build();

hub.On<string, List<SendPackage>>("channel", (user, msg) =>
{
      //使用消息中心进行进程内转发
      MessageCenter.Send(new { }, "channel", msg);
});

await hub.StartAsync();
其他阅读

管道技术——中间件的灵魂

在现代Web开发中,中间件技术使用越来越广泛,本文带大家了解中间件的基础,同时也是中间件的灵魂所在,管道技术。在C#中,依赖于委托,我们可以很容易就实现一个中间件管道。所以在阅读本文前,请确保你已经学会了什么是委托,包括但不限于Delegate,Action,Func。除此之外,本文还会使用到反射相关知识,请确保你已经学会了什么是反射。

查看原文

C#扩展方法

一般来说,当我们使用某个类时,需要用到一些特别的方法,但却没有时。一般做法可能是创建一个基于该类的派生类,添加我们想要的方法,但这样做无疑增加了复杂度。所以这时候,扩展方法出现了。

查看原文

LinqPad 8 分享下载

LinqPad是一个 .Net 快速验证工具,使得.Net开发者可以不借助 Visual Studio 就可以快速验证想法,毕竟vs冷启动和创建项目耗时久,负担大。本文分享一个LinqPad学习版,可直接下载使用。

查看原文

Fetch发送请求

fetch 是 javascript 中一个新的 api,用于访问和控制 HTTP 的请求和响应等,不再需要使用传统的 XMLHttoRequest

查看原文

Entity Framework Core链接Oracle的问题

最近使用 Entity Framework Core 来链接 Oracle 11g 数据库,发现很多 LINQ 语句使用起来都会有问题,查看日志输出发现是生成SQL语句无法被 11g 版本执行,好在Oracle官方已经给我们提供了解决方案。

查看原文