Mirror学习笔记(一) 简介
文章目录
- 一、常规学习:
- Mirror核心功能有
- 服务器和主机
- 二、时间戳批处理
- 时间戳
- 三、TCP和UDP
- 四、CCU(同时在线人数)
- 五、SyncDirection(同步方向)
- 六、RTT(往返时间)
- 七、Connection Quality(连接质量)
- 八、Lag Compensation(滞后补偿)
- 一、独立算法类LagCompensation.cs
- 二、Log Compensator组件
- 九、Client Side Prediction(客户端预测)
- 十、History Bounds(历史边界)
一、常规学习:
Mirror是一个用于Unity多人游戏的功能系统。它允许在其中一个参与者同时承担服务器的功能,因此不需要专用的服务器进程从而减少了开发人员的工作量。
Mirror核心功能有
1.消息处理程序
2.通用高性能序列化
3.分布式对像管理
4.状态同步
5.服务器与客户端的各种链接等.
服务器和主机
1.服务器是游戏的一个实例,所有客户端与其链接。由服务器对数据进行处理并回传给各客户端展示。
2.服务器可以是“专用服务器”
也可以是“主机服务器”。
“专用服务器”
仅作为服务器支行游戏实例。
“主机服务器 “
当没有专用服务器时,即充当服务器也充当客户端。
下图代表了三个玩家。在游戏充当了主机也就是本地客户端,并且两者在同一客户端支行。另外两个是远程客户端。
因为主机与本地服务器在同一进程中,因而可以使用“特殊”
的通讯方便直接调用方法和消息。
远端客户端则通过常规的网络通讯与服务器交互,Mirror会自动处理这些工作。
多人游戏系统目标之一是使服务端、客户端代码相同。因而多数时候你只需要考虑一种类型的客户端,Mirror将会自动处理差异。
二、时间戳批处理
你发送的每条消息将被批处理直至当前帧结束,以最大程度的减少传输的消耗。消息中将会把大量的小消息合并为一条进行发送。
客户端和服务端都会进行批处理以最大化的减少性能消耗。
时间戳
确保远程发送消息的时序性,接收到消息后对他们之间进行插值。可以准确的知道物在服务器上,何时处于何处。
早期版本通过NetworkTransform来实现,成本巨大因为需要包含一个4字节(float),甚至8字节(double),当在大型游戏中时,宽带压力会迅速增加。
而NetworkTransform只是其中一种组件,其他的组件也可能需要时间戳,这将进一步增加宽带消耗。
为了减轻宽带压力,Mirror每个批次都包含8个字节,但并不是每条消息都包含,而是每1200个字节批出来一次,这有效减轻了宽带压力。
在客户机上,所有对象数据都以消息/批处理的形式从服务器到达。因此,在任何给定的时间,您都可以发现对象的Rpc/OnDeserialize/OnMessage处理程序何时由服务器通过NetworkClient.connection.remoteTimeStamp发送。
在服务器上,只有玩家拥有的对像才能于家连接中获得消息。因此,在任何时间,您都可以找到对像的Cmd/OnDeserialize/OnMessage处理程序,由客户端能过connectionToClient.remoteTimeStam发送
三、TCP和UDP
TPC由1970年开发,UDP由1980年引入,TCP内靠性,时序性,但延迟较高,UDP反之。
四、CCU(同时在线人数)
Mirror 可以处理多少个CCU,通常来说每个地图可以处理200CCU,但理论上是可以达到1000个。
官方尝试了一些项目480CCU时已有些卡顿,同时3D比2D的开销会更大。
五、SyncDirection(同步方向)
Mirror新增了SyncDirection功能
Mirror 中通常从服务器同步到客户端,但某些组件(如:NetworkTransform)需要在客户权限的情况下同步到服务器,因为OnSerialize只会从服务器到客户端,这里有几个缺点:
1.同时进行OnSerialize和手动远程调用需要大量的额外代码
2.会有额外宽带消耗,因每个命令包含一个函数哈希
3.间隔需要手动实现,因为syncInterval仅适用于OnSerialize.
因此OnSerialize提供了从客户端同步到服务器,组件提供了SyncDirection功能。
六、RTT(往返时间)
往返时间是指消息到另一端并返回的时间,由以下两个因素决定:
1.延迟:网络通过互联网传播需要时间
2.更新间隔:消息需要被处理并发送回另一端,与服务器处理时间及压力有关。
用户可以在NetworkTime.rtt查看,服务器可以在每个不同链接的NetworkServer.connection.rtt查看
如果你想在游戏中显示rtt可以使用NetworkPingDisplay
七、Connection Quality(连接质量)
Mirror的连接由三部分组成:
ConnectionQuality.cs提供了以下连接质量级别:
Public enum ConnectionQuality : byte
{
EXCELLENT, //高水平理想体验
GOOD, //非常适合所有人,高水平连接
FAIR, //非常明显卡顿,让人不愉悦
POOR, //无效的玩家
ESTIMATING, //仍在评估
}
两种发起方式:
Simple(based on Ping & Jitter)
Pragmatic( 基于快照插值)
NetworkPingDisplay
此组件可以添加到NetworkManager中,以在屏幕右下角显示ping和连接质量指示
NetworkManager回调
以覆盖CalculateConnectionQuality方式注入。可以在NetworkManager中配置。
OnConnectionQualityChanged可用于向用户显示警告,默认情况 下会发出一条日志。
八、Lag Compensation(滞后补偿)
快节奏的第一人称射击需要延迟补偿,又叫回滚。而对于MMORPG、纸牌、回合、等策略则不需要。
为什么需要回滚,假设在设计游戏中你和另一名玩家同步需要50毫秒,到达服务器需要50毫秒。这里就有100毫秒的时间差。这100毫秒里可能对方发生了位移,可能使你的设计位置不准确。
滞后补偿分为两部分:
一、独立算法类LagCompensation.cs
该算法可以记录采样类型任何记录。
换句话说,如果你愿意,您可以根据自己的需要定制它,这是底层代码,使用高级组件会更方便。
二、Log Compensator组件
只需要添加下面组件,Mirror将会管理指定Collider的历史快照。
当你做为玩家在本地发射子弹时,[Command]将输入发送到服务器,这进我们不检查另一端玩家是否补击中,
而是检查另一端玩家当时的Lag Compensation(滞后补偿)
官方文档中提供了例子。
九、Client Side Prediction(客户端预测)
打开Examples/Billiards例子,选择NetworkManager -> LatencySimulation 增加一些延迟(50ms),构建选择Server Only.
这是一个桌球游戏,在你击打白球时,由于数据需要发送给服务器再回传我们能明显的感觉到打击感滞后。
因此我们需要要用客户端模拟预测结果,一旦服务端返回状态我们必须立马纠正它。
由于大多数物理引擎,如Unity的PhysX是不确定的。这以为着在客户端和服务端施加的力(浮点数)会有所不同,而差异会逐渐累计。
为什么不使用确定性物理引擎:
一、Unity没有
二、工作量大
三、比常规物理引擎慢
最简单回滚流程说明:
由客户端执行Rigidbody.AddForce() 同时发送给服务器端执行[Command]CmdApplyForce(force)
服务器执行wellRigidbody.AddForce(force)
服务器同步新的刚体位置到客户端,但些修正将有一定时间差,而客户端一直在进行修改。
这也以为着客户端将一直有明显的“后跳”行为。
应当如何解决因时间差带来的后跳问题呢?
由客户端执行Rigidbody.AddForce() 客户端保存刚体位置 每50ms保存一次,以便后面进去比较
发送给服务器端执行[Command]CmdApplyForce(force)
拿到服务端的位置后与100ms(50+50来回)前的位置进行对比矫正
这部分内容可以了解一下而已,事实上Mirror已经为我们处理完这部分内容
在客户端中使用:Predicted Rigidbody(预测刚体)插件,情况将会简单很多。
预测和修正总是很难应用在刚体上。为了固话效果组件提供了两种模式:
Smooth(平滑):一般开始移动,所有的物理组件(Rigidbody+Colliders)都会移动到一个不可见的Ghost对象里。
渲染器在原位置并平滑插值到Ghost对像的位置,这将提供非常平滑的结果,但创造和跟随会有更大的额外成本开销。
Fast(快速):物体保留在原来的位置上,渲染器直接移动到结果所在位置,这种方式更节约性能。
关于预测的类型可以在forecast .cs中找到它。
Mirror还可以用于其他类型的预测,但还需要了解后自行补全部分逻辑。
关于Mirror对于大型场景的预测
传统上预测算法并回滚模拟整个场景我们需要Physics.Simulate()
此方法可以最正确的模拟出结果,但性能消耗巨大,不适合用于大型场景。
Mirror经过努力兼容了大型场景的物理同及堆叠物理的同步。
十、History Bounds(历史边界)
优化延迟补偿和客户端预测,为了最小化性能开销,在我们使用的对像先对其强制使用HistoryBounds
使用方式:
将HistoryCollider添加到NetworkIdentity上
确保NetworkIdentity中有碰撞器,并拖至actualCollider中
按下播放键,启动Gizmos,注意橙色的HistoryCollider.
组件以橙色包围盒显示,这以为着您可以使用物理摄像进行物理检测。
当玩家开枪时,对所有的HistoryColliders进行射线检测,反出我们需要检测的玩家。
然后对碰撞器的父级NetworkIdentity使用延迟补偿处理,然后再检查他是否补击中。
相关文章:

Mirror学习笔记(一) 简介
文章目录 一、常规学习:Mirror核心功能有服务器和主机 二、时间戳批处理时间戳 三、TCP和UDP四、CCU(同时在线人数)五、SyncDirection(同步方向)六、RTT(往返时间)七、Connection Quality(连接质量)八、Lag Compensati…...

终端pip安装包后,Pycharm却导入失败?新手别慌,3招搞定!
很多小伙伴在学习Python的过程中,都会遇到这种情况:明明在终端用pip安装好了需要的包,但在Pycharm中导入时却报错。难道是安装姿势不对? 例如在cmd中已经有了pandas,但是去pycharm中导入pandas显示没有 先别急着怀疑人生,这很可能是因为pip安装包的路径和Pycharm项目使用…...

Redis 与 Scrapy:无缝集成的分布式爬虫技术
1. 分布式爬虫的概念 分布式爬虫系统通过将任务分配给多个爬虫节点,利用集群的计算能力来提高数据抓取的效率。这种方式不仅可以提高爬取速度,还可以在单个节点发生故障时,通过其他节点继续完成任务,从而提高系统的稳定性和可靠性…...

大厂linux面试题攻略四之Linux网络服务(一)
一、Linux网络服务-SSH服务 1.哪些设置能够提升SSH远程管理的安全等级? ssh的登录验证方式 ssh的登录端口和监听设置: 配置文件: /etc/ssh/sshd_config #Port 22 #ssh服务默认监听端口 #ListenAddress 0.0.0.0 #ssh服务…...

【Pulling fs layer】Linux使用docker-compose的时候,一直Pulling fs layer
当Docker在拉取镜像时卡在“pulling fs layer”阶段,可以通过重启Docker服务来解决。 具体步骤如下: 首先,尝试重启Docker服务。可以通过运行以下命令来重启Docker服务: systemctl restart docker 这个命令会重启Docker服务…...

最新保姆级教程使用WildCard开通Claude3升级ChatGPT4.0(2024.8)
如何使用 WildCard 服务注册 Claude3 随着 Claude3 的震撼发布,最强 AI 模型的桂冠已不再由 GPT-4 独揽。Claude3 推出了三个备受瞩目的模型:Claude 3 Haiku、Claude 3 Sonnet 以及 Claude 3 Opus,每个模型都展现了卓越的性能与特色。其中&a…...

layui 乱入前端
功能包含 本实例代码为部分傻瓜框架,插入引用layui。因为样式必须保证跟系统一致,所以大部分功能都是自定义的。代码仅供需要用layui框架,但原项目又不是layui搭建的提供解题思路。代码较为通用 自定义分页功能自定义筛选列功能行内编辑下拉、…...

中国十大顶级哲学家,全球公认的伟大思想家颜廷利:人类为何拥有臀部
人类为何拥有臀部?若众生皆无此部位,又如何能寻得一处真正属于自己的“座位”?在博大精深的中国传统文化中,汉字“座”与“坐”均蕴含“土”字元素。在易经的智慧里,作为五行之一的“土”,象征着人类社会的…...

Threejs中导入GLTF模型克隆后合并
很多场景中会需要同一个模型很多次,但是如果多次加载同一个模型会占用很高的带宽,导致加载很慢,因此就需要使用clone,也就是加载一个模型后,其他需要使用的地方使用clone的方式复制出多个同样的模型,再改变…...

今日arXiv最热大模型论文:北京大学最新综述:视觉大模型中的漏洞与攻防对抗
近年来,视觉语言大模型(LVLM)在文本转图像、视觉问答等任务中大放异彩,背后离不开海量数据、强大算力和复杂参数的支撑。 但是!大模型看似庞大的身躯背后却有一颗脆弱的“心脏”,极易受到攻击。攻击者可以…...

为什么IDEA中使用@Autowired会被警告
我们在使用IDEA编码时,如果用到了Autowired注解注入bean,会发现IDEA会给代码标个波连线,鼠标移动上去,会发下idea提示:不推荐使用Filed injection,这是Spring的核心DI(Dendency Injection&#…...

uniapp使用cover-view,使用@click无效
最近要做直播详情页面,用的是第三方直播链接,需要在该页面上放两个按钮,点击按钮需要弹出相关商品及优惠券。类似于抖音直播页面。 第三方链接使用的是web-view进行展示。由于该组件优先级太高,正常的前端组件无法在该页面浮现展…...

Postman 接口测试工具简易使用指南
一、Postman是什么? 我通过kimi问了这样一个问题,它给我的回答是这样的: 它的回答也算比较中规中矩,简单的说postman实际上就是一款接口测试工具,同时它还可以编写对应的测试脚本以及自动生成对应的API文档,结合我的习惯来说&am…...

Move生态:从Aptos和Sui到Starcoin的崛起
区块链技术自诞生以来,已经经历了多个发展阶段和技术迭代。近年来,随着智能合约平台的不断演进,以Move语言为核心的生态系统逐渐崭露头角。Move语言以其安全性、灵活性和高效性吸引了大量开发者和项目方的关注。在Move生态中,Apto…...

MacOS DockerDesktop配置文件daemon.json的位置
如果因为通过可视化页面修改配置错误导致客户端启动不起来,可以去找对应的配置文件通过 vim 修改后重启客户端 cd ~/.docker/...

从光速常数的可变性看宇宙大爆炸的本质
基于先前关于光速本质的讨论,让我们从函数图像看看宇宙大爆炸到底是什么。 先前已经讨论过,在量子尺度上,长度的实际对应物是频率的差异,因为只有频率差异才能在这个尺度上区分相邻时空的两点,而两点之间“差异的大小”…...

敢不敢跟我一起搭建一个Agent!不写一行代码,10分钟搞出你的智能体!纯配置也能真正掌握AI最有潜力的技术?AI圈内人必备技能
说一千道一万,不如实地转一转。学了那么久的AI Agent的概念了,是时候该落地一个Agent看看自己的掌握程度了对不对,我们都理解大脑是自动节能的,但是知识的确需要倒逼自己一把才能真的掌握,不瞒大家说,笔者对…...

vue3和vite双向加持,uni-app性能爆表,众绑是否有计划前端升级到vue3!
uni-app官方已经开始不支持vue2了,而且即将适配的鸿蒙next原生系统,也不支持vue2打包,CRMEB是否有计划跟上潮流呢,如果有会在什么时间呢,有准确的时间表吗?我们非常期待得到答案! 新版 uni-app…...

2024年最强网络安全学习路线,详细到直接上清华的教材!
关键词:网络安全入门、渗透测试学习、零基础学安全、网络安全学习路线 首先咱们聊聊,学习网络安全方向通常会有哪些问题前排提示:文末有CSDN官方认证Python入门资料包 ! 1、打基础时间太长 学基础花费很长时间,光语…...

人脸识别又进化:扫一下 我就知道你得了啥病
未来,扫下你的脸,可能就知道你得啥病了。没在瞎掰,最近的一项研究成果,还真让咱看到了一点眉目。北大的一个研究团队,搞出来一个 AI ,说是用热成像仪扫一下脸,就能检测出有没有高血压、糖尿病和…...

yolov8标注细胞、识别边缘、计算面积、灰度值计算
一、数据标注 1. 使用labelme软件标注每个细胞的边界信息,标注结果为JSON格式 2. JSON格式转yolo支持的txt格式 import json import os import glob import os.path as osp此函数用来将labelme软件标注好的数据集转换为yolov5_7.0sege中使用的数据集:param jsonfi…...

WEB前端11-Vue2基础01(项目构建/目录解析/基础案例)
Vue2基础(01) 1.Vue2项目构建 步骤一:安装前端脚手架 npm install -g vue/cli步骤二:创建项目 vue ui步骤三:运行项目 npm run serve步骤四:修改vue相关的属性 DevServer | webpack //修改端口和添加代理 const { defineCo…...

QT--线程
一、线程QThread QThread 类提供不依赖平台的管理线程的方法,如果要设计多线程程序,一般是从 QThread继承定义一个线程类,在自定义线程类里进行任务处理。qt拥有一个GUI线程,该线程阻塞式监控窗体,来自任何用户的操作都会被gui捕获到,并处理…...

通过进程协作显示图像-C#
前言 如果一个软件比较复杂或者某些情况下需要拆解,可以考试将软件分解成两个或多个进程,但常规的消息传递又不能完全够用,使用消息共享内存,实现图像传递,当然性能这个方面我并没有测试,仅是一种解决思路…...

LangChain链与记忆处理[10]:四种基础内置链、四种文档处理链,以及链的自定义和五种运行方式,让你的大模型更加智能
LangChain链与记忆处理[10]:四种基础内置链、四种文档处理链,以及链的自定义和五种运行方式,让你的大模型更加智能 参考文章可以使用国产LLM进行下述项目复现: 初识langchain[1]:Langchain实战教学,利用qwen2.1与GLM-4大模型构建智能解决方案[含Agent、tavily面向AI搜索…...

京东发行稳定币的背后
加密市场很热,京东也要来分一杯羹? 7月24日,据财联社报道,京东科技旗下的京东币链科技 ( 香港 ) 将在香港发行与港元 1:1锚定的加密货币稳定币,在市场上掀起广泛热议。 由于众所周知的监管原因,国内大厂在早…...

CF1995C Squaring 题解
思路详解: 请注意,本题解用到了非整数计算,也就是说性能可能不如整数运算,但是易于实现,追求最优解的大佬不建议观看本题解。 这个题看似简单,但是由于涉及到了平方操作,不用高精度根本存不下&…...

动态规划之路径问题
动态规划算法介绍 基本原理和解题步骤 针对于动态规划的题型,一般会借助一个 dp 表,然后确定这个表中应该填入什么内容,最终直接返回表中的某一个位置的元素。 细分可以分为以下几个步骤: 创建 dp 表以及确定 dp 表中所要填写位…...

如何优化你的TikTok短视频账号运营策略?
在运营TikTok账号时,采取正确的策略至关重要,这些策略能够帮助你提升账号的质量和吸引力。 适度使用互粉互赞 避免过度依赖互粉互赞,因为这可能会限制你的内容在更广泛的观众中传播。虽然互粉互赞可以增加曝光,但过度使用可能导…...

mysql的唯一索引和普通索引有什么区别
在MySQL中,唯一索引(UNIQUE Index)和普通索引(普通索引,也称为非唯一索引)有一些关键的区别。以下是它们的比较以及性能分析: 唯一索引与普通索引的区别 唯一性: 唯一索引ÿ…...