Mirror网络库 | 实战

此篇为下文,上篇:Mirror网络库 | 说明

一、官方实例说明

场景名说明
AdditiveLevels场景为“关卡”,附加形式加载
AdditiveScenes加载卸载附加场景
Basic基础的连接/断开,消息发送
Benchmark服务器1000“怪物”生成性能测试
BenchmarkIdleTCP协议服务器5000“NPC”生成性能测试
CCU服务器10000“怪物“生成性能测试
Chat简单的聊天室
DiscoveryUDP广播查找并连接服务器
LagCompensation延迟补偿
MultipleAdditiveScenes多场景附加加载
MultipleMatches多端匹配内置井字棋
Pong乒乓球游戏
RigidbodyBenchmark服务器2000”Server Ball"生成性能测试
RigidbodyPhysics刚体物理模拟
Room模拟大厅游戏的房间
Snapshot Interpolation快照插值
SyncDirection同步方向
Tanks / TanksCoop坦克大战
VR官方示例地址

以HostMode进行测试
多端测试工具

  • AdditiveLevels:以Offline作为启动场景,AdditiveLevelsNetworkManager的SceneManagement的OfflineScene和OnlineScene对应上示例的Offline和Online;选择附加(Additive Scenes)的场景为SubLevel1和SubLevel2。SubLevel1和SubLevel2中的Portal的DestinationScene选择对方。整体流程:Offline场景运行 -> 附加加载OnlineScene为“游戏环境”,SubLevel1和SubLevel2为“关卡”场景,默认显示SubLevel1(First is start scene) -> 移动到标有SubLevel1字样的物体,则切换到SubLevel2(关卡2),同理,移动到标有SubLevel2字样的物体,则切换到SubLevel1(关卡1)。
  • AdditiveScenes:以MainScene为启动场景,不需要设置OfflineScene和OnlineScene的默认“环境”,SubScenes中添加SubScene作为附加场景。整体流程:MainScene场景运行 -> 附加加载SubScene -> 移动到一定范围内重新LoadScene并且使用InterestManagement的距离类型过滤掉其他Observers。
  • Basic:BasicNetManager的OnServerAddPlayer和OnServerDisconnect监听Player.ResetPlayerNumbers方法,此方法标记了[ServerCallback]且为internal static,记录Player类的playerNumber从0递增,表示加入的“玩家编号”。Player类的OnStartServer中存储自身到容器,且设置color和data。至此,服务器改变了playerNumber、playerColor、playerData三者的值,通过SyncVar属性及hook钩子这些变量值变化时会触发对应的Method,而Method中包含了对应的事件调用。Player类中的OnStartClient中,对这些事件进行了PlayUI中的实际方法绑定及Invoke。整体流程:开启主机模式 -> 服务器为Player00,其Data每隔1秒在[100, 1000)之间切换 -> 加入一台客户端(玩家) -> 玩家为Player01,Data同样在1秒内切换一次。Stop则断开连接,对应的PlayerUI消失。
  • Benchmark:运行之后,Snapshot Interp这一块的参数值来自于NetworkClient的OnGUI,在NetworkManager(抽象类)的OnGUI中调用;timeline(经过快照插值处理后的远程服务器的时间)、buffer(时间快照数量)、DriftEMA(ExponentialMovingAverage:指数移动平均线。平均最后一秒的快照时间差)、DelTimeEMA(传输时间的指数移动平均线)、timescale(每个update中调整本地时间标尺)、BTM(存储的快照插值运行数据缓冲时间乘数)、RTT(消息从client->server->client的时间,单位:秒)、SendRate(消息发送间隔,单位:Hz,1/sendrate=ms,针对时间和值快照插值。这个是博主自己添加的一个参数打印) 。底部的Radius滑条是SpatialHashingInterestManagement的OnGUI,影响visRange,其CheckMode分为2D和3D两种模式。
  • BenchmarkIdle:TCP协议服务器生成完毕,编辑模式花费35秒;客户端加入花费2秒;传输数据方面客户端send大概在320-580B/s,recv大概在712KB/s-1.04MB/s;服务器send大概在1.04MB/s,recv大概在385B/s-704B/s。替换为KCPTransport后,数据基本没有倍数变化。
  • CCU:Client/Server Statistics这个是NetworkStatistics的OnGUI绘制的。这个生成好快!把BenchmarkIdle的Interleave从2改为10,结果生成花费的时间基本不变,因为这个参数只是改变了间隔距离,生成数量没变;换成KCP + DistanceInterestManagement花费时间没咋变化,fps有很大提升。这里生成时间能否节省?如果不能节省就提前生成?
  • Chat:有一个ChatAuthenticator,验证消息传递,用户登录,可以像Basic那样扩展离线通知。对于需要身份验证、保证消息可靠传递可以参考这个示例。
  • Discovery:WebGL不支持。开启udp循环广播,进行监听,查找可连接的服务器,请求连接。**扩展:服务器断开,那么客户端的Find Servers列表要响应清楚该Server。**这个可以应用在app查找可用服务?
  • LagCompensation:Fps games非常有用,避免明明瞄准了打的枪,结果敌方没死掉。通过存储player的快照,在不同的网络情况下,预测不同客户端的时间,算出对应时刻的玩家位置,再进行判定。
  • MultipleAdditiveScenes:这个和AdditiveScenes很像。设置MultiSceneNetManager的Instances(场景实例个数)和GameScene(场景),运行,会附加加载指定个数的指定场景。
  • MultipleMatches:这个有点像腾讯游戏大厅之类的下象棋游戏,任何一端可以创建一个房间,建房的端可以等进入房间的人都处于Ready状态时,就开始游戏。示例实现了一个简单的回合制井字棋游戏。
  • Pong:看到这里的时候,可以发现基本上就是NetworkBehaviour、NetworkManager、NetworkTransform这些东西整来整去,整个框架的使用应该时不难的,但是想看核心的东西也比较难吭,比如:如何做到双端一个工程,发布后逻辑自动划分的?为什么要带一个Mono.Cecil?Weaver是干嘛的?能不能快速替换Transoport以适应不同的网络、平台等情况?组件和常用核心代码的应用场景?
  • RigidbodyBenchmark:虽然只有2000个,相对前面的几万个来说比较少,但是这个好快!用了延迟模拟+SpatialHashingInterestManagement。这个才是正确使用方式么…
  • RigidbodyPhysics:案例没得ReadMe,咋一看NetworkManager也没有业务子类,上面也没啥可疑参数,ok,看Scripts找到按空格键施加一个向上的力这么一段代码。模拟的力有点假,特别是小球向上的力和重力抵消,快要消失的时候,太生硬了。
  • Room:这个和Lobby还是有点区别的,应该说默认就在房间,然后再ready->play,没有在大厅创建房间这一步。上面的MultipleMatches有建房间,且任意一端均可以。
  • Snapshot Interpolation:延迟补偿的原理因素之一。
  • SyncDirection:谁给谁做同步。HostMode把Player上的SyncDirection改为ServerToClient,然后空格改值,该值的变化会同步到Client端。示例用了SyncVar和SyncList这两个来做同步测试。这个案例虽然比较简单,但是可以解决**如何做到双端一个工程,发布后逻辑自动划分的?**这个问题。可以看看代码,路径还是挺清晰的。
  • Tanks / TanksCoop:坦克大战小游戏,就是不能后退有点蠢…可以看看ClientRpc的使用。

二、多路复用器测试(PC + Android + Webgl)

  • Tanks的sendRate = 120之后,PC发布包测试,RTT并没有到1,是我的工作电脑cpu不行么?哈哈
  • 本来想做个KCP+RPC+Lantency Simulation的功能测试,但是实例看完,这些都包含了,不做了。
  • 最后,整一个Multiplex测试~

MultiplexTransport:KcpTransport(PC + Android) + SimpleWebTransport(Webgl)
在这里插入图片描述
NetworkManager -> MultiplexTransport -> KcpTransport(1) + SimpleWebTransport(2)
官方教程

  • PC + Android,借用官方示例的Chat示例,没有问题
  • webgl没有服务器测试…还要配置ssl(后面有机会补齐哈 …)
  • 如果想单纯的使unity和webgl交互,协议采用websocket,推荐用这个库:UnityWebSocket

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/95362.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IL汇编ldc指令学习

ldc指令是把值送到栈上, 说明如下, ldc.i4 将所提供的int32类型的值作为int32推送到计算堆栈上; ldc.i4.0 将数值0作为int32推送到计算堆栈上; ... ldc.i4.8 将数值8作为int32推送到计算堆栈上; ldc.i4.m1 将数值-…

【开源分享】在线客服系统搭建-基于php和swoole客服系统CRMchat(附源码完整搭建教程)...

CRMChat是一款开源的在线客服系统,后台管理使用thinkphp框架,消息通讯使用swoole扩展,现在我来部署搭建一下。 这是一款不可商用的开源客服系统,如果有商用需求可以访问我的网站:gofly.v1kf.com 域名解析 以阿里云为例…

WebRTC | ICE详解

目录 一、Candidate种类与优先级 二、ICE策略 1. iceServers 2. iceTransportPolicy 三、P2P连接 1.Nat类型 (1)完全锥型NAT (2)IP限制锥型NAT (3)端口限制锥型NAT (4)对称…

springboot、java实现调用企业微信接口向指定用户发送消息

因为项目的业务逻辑需要向指定用户发送企业微信消息&#xff0c;所以在这里记录一下 目录 引入相关依赖创建配置工具类创建发送消息类测试类最终效果 引入相关依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-…

在Centos环境中搭建Nginx环境

一、Nginx概念简介 Nginx是一个轻量级的高性能HTTP反向代理服务器&#xff0c;同时它也是一个通用类型的代理服务器&#xff0c;支持绝大部分协议&#xff0c;如TCP、UDP、SMTP、HTTPS等。 Nginx与redis相同&#xff0c;都是基于多路复用模型构建出的产物&#xff0c;因此它与R…

利用Opencv实现人像迁移

前言&#xff1a; Hello大家好&#xff0c;我是Dream。 今天来学习一下如何使用Opencv实现人像迁移&#xff0c;欢迎大家一起参与探讨交流~ 本文目录&#xff1a; 一、实验要求二、实验环境三、实验原理及操作1.照片准备2.图像增强3.实现美颜功能4.背景虚化5.图像二值化处理6.人…

20W IP网络吸顶喇叭 POE供电吸顶喇叭

SV-29852T 20W IP网络吸顶喇叭产品简介 产品用途&#xff1a; ◆室内豪华型吸顶喇叭一体化网络音频解码扬声器&#xff0c;用于广播分区音频解码、声音还原作用 ◆应用场地如火车站、地铁、教堂、工厂、仓库、公园停车场等&#xff1b;室内使用效果均佳。 产品特点&#xff…

BC136 KiKi去重整数并排序

给定一个整数序列&#xff0c;KiKi想把其中的重复的整数去掉&#xff0c;并将去重后的序列从小到大排序输出。 输入描述 第一行&#xff0c;输入一个整数n&#xff0c;表示序列有n个整数。 第二行输入n个整数&#xff08;每个整数大于等于1&#xff0c;小于等于1000&#xf…

学校信息管理系统说明文档

目录 0学生信息管理系统体验教程. 4 0.0Student management异地打开方法&#xff1a;. 4 1. 管理系统设计需求分析. 6 1.1 需求介绍. 6 1.2功能需求. 6 1.2.1 学生信息录入. 6 1.2.2 学生信息查询. 6 1.2.3 权限管理. 6 1.2.4 添加学生信息验证. 6 2.功能介绍. 7 2.1…

C++中String的语法及常用接口用法

在C语言中&#xff0c;string是一个标准库类&#xff08;class&#xff09;&#xff0c;用于处理字符串&#xff0c;它提供了一种更高级、更便捷的字符串操作方式&#xff0c;string 类提供了一系列成员函数和重载运算符&#xff0c;以便于对字符串进行操作和处理。 一、string…

步步为赢:打造一个酷炫而吸引人的Hadoop HDFS分布式文件系统集群部署方案

文章目录 版权声明一 分布式存储缘起二 分布式的基础架构2.1 大数据架构模式2.2 主从模式 三 HDFS的基础架构HDFS的角色组成 四 HDFS集群环境部署4.1 安装包下载4.2 Hadoop安装包目录结构4.3 修改配置文件&#xff0c;应用自定义设置4.4 分发Hadoop文件夹4.5 配置环境变量4.6 授…

Ubuntu安装最新版neovim

Ubuntu安装最新版neovim 一、前言 对于neovim版本很重要&#xff0c;有很多插件几乎都要要求neovim版本在0.8或者0.9。但是有一个很严重的问题就是&#xff0c;Ubuntu使用sudo apt install neovim的版本很低达不到要求&#xff08;写文章时是0.7&#xff09; 二、解决方法 …

罗勇军 →《算法竞赛·快冲300题》每日一题:“质因子数量” ← 快速幂、素数筛

【题目来源】http://oj.ecustacm.cn/problem.php?id1780http://oj.ecustacm.cn/viewnews.php?id1023【题目描述】 给出n个数字&#xff0c;你可以任意选择一些数字相乘&#xff0c;相乘之后得到新数字x。 其中&#xff0c;x的分数等于x不同质因子的数量。 请你计算所有选择数…

企望制造ERP系统 RCE漏洞[2023-HW]

企望制造ERP系统 RCE漏洞 一、 产品简介二、 漏洞概述三、 复现环境四、 漏洞复现小龙POC检测 五、 修复建议 免责声明&#xff1a;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;…

JDBC封装与设计模式

什么是 DAO &#xff1f; Data Access Object(数据存取对象) 位于业务逻辑和持久化数据之间实现对持久化数据的访问 DAO起着转换器的作用&#xff0c;将数据在实体类和数据库记录之间进行转换。 ----------------------------------------------------- DAO模式的组成部分 …

考研算法第46天: 字符串转换整数 【字符串,模拟】

题目前置知识 c中的string判空 string Count; Count.empty(); //正确 Count ! null; //错误c中最大最小宏 #include <limits.h>INT_MAX INT_MIN 字符串使用发运算将字符加到字符串末尾 string Count; string str "liuda"; Count str[i]; 题目概况 AC代码…

【自用】云服务器 docker 环境下 HomeAssistant 安装 HACS 教程

一、进入 docker 中的 HomeAssistant 1.查找 HomeAssistant 的 CONTAINER ID 连接上云服务器&#xff08;宿主机&#xff09;后&#xff0c;终端内进入 root &#xff0c;输入&#xff1a; docker ps找到了 docker 的 container ID 2.config HomeAssistant 输入下面的命令&…

音视频FAQ(一):视频直播卡顿

一、摘要 本文介绍了视频直播卡顿的四个主要原因&#xff0c;用户网络问题、用户设备性能问题、技术路线的选择和实现问题。因本文主要阐述视频直播的卡顿&#xff0c;故技术路线的实现指的是&#xff1a;CDN供应商的实现问题&#xff0c;包含CDN性能不足、CDN地区覆盖不足。对…

【JAVA】我们该如何规避代码中可能出现的错误?(一)

个人主页&#xff1a;【&#x1f60a;个人主页】 系列专栏&#xff1a;【❤️初识JAVA】 文章目录 前言三种类型的异常异常处理JAVA内置异常类Exception 类的层次 前言 异常是程序中的一些错误&#xff0c;但并不是所有的错误都是异常&#xff0c;并且错误有时候是可以避免的&…

Spring Cloud面试突击班1

Spring Cloud面试突击班1 1.Spring Cloud 中有哪些组件&#xff0c;整个项目架构中我们的重点又有哪些&#xff1f; Spring Cloud 是一套基于Spring Boot的微服务解决方案。 Spring Cloud生态在国内主流的分为两套&#xff0c;一套是以奈飞开源的Spring Cloud Netfilx 20%&a…