UE4 RPC进行网络同步

说明

基于UE本身提供的RPC同步机制

RPC远程过程调用允许客户端或服务器通过网络连接相互发送消息:

使用时需要注意:

1、必须从 Actor 上调用

2、Actor 必须被复制,注意勾选BP中Replicates,或使变量bReplicates = true

3、注意如果 RPC 是从Client调用并在Server上执行,客户端就必须拥有调用 RPC 的 Actor。

所以在属性同步的地方设置此Actor的Owner,主要用于网络复制,玩家离开交互时Owner置空

PS:引申:考虑到每一位客户端对该actor接管网络消息所有权都需要SetOwner,可能会导致网络延迟或安全性隐患,此处可以根据实际情况进行优化为通过经过玩家进行RPC同步,如由玩家的component发起。

从Server调用RPC的作用范围

从Client调用RPC的作用范围

DS同步处理

一般建议数据全部由DS服务器持有/转发同步,此处由主端玩家进行数据推送同步

可以理解为主端数据变化 -> 同步DS -> 广播给其他所有客户端

PS:在保证性能的前提下,决策/校验更多在server端处理

服务端的处理:定义自定义事件,注意勾选同步范围,代表客户端同步在仅Server运行

脚本或蓝图可以主动调用该事件,服务器收到该结构体,广播给其他客户端

客户端的处理:

可以自定义函数可由脚本重写,来处理收到消息后的逻辑

Struct可由各业务自定义,灵活使用

相关推荐
haluhalu.3 分钟前
Socket编程踩坑记:为什么accept返回的socket fd总是0?
linux·服务器·网络
WJ.Polar4 分钟前
Ansible Ad-Hoc命令
linux·运维·网络·ansible
崎岖Qiu6 分钟前
【计算机网络 | 第十八篇】子网掩码和子网划分方法
网络·计算机网络·子网划分·子网掩码
云边云科技_云网融合10 分钟前
SD-WAN 专线:为亚马逊云、微软云访问提速的核心逻辑
网络·人工智能·安全·microsoft·架构
kjmkq12 分钟前
适合卫星物联网的存储模块 天硕(TOPSSD)为万物互联的太空网络提供存储支撑
网络·物联网·servlet
测试专家14 分钟前
ARINC 825协议的技术核心
网络
SC_CSDN_L14 分钟前
【精选记录】解决VMware中Linux虚拟机桥接模式下ping 出现DUP(重复包)问题
linux·服务器·网络·dup
无忧智库16 分钟前
低空经济爆发前夜:某试验区“十五五”通航机场与无人机物流网络建设深度解析(WORD)
网络·无人机
物联网软硬件开发-轨物科技16 分钟前
【轨物方案】无刷 vs 有刷:针对不同电站需求的清洁机器人智能硬件选型指南
网络·机器人·智能硬件
深圳市恒讯科技18 分钟前
大带宽服务器如何降低网络延迟?网络优化方案解析
运维·服务器·网络