当前位置: 首页 > news >正文

游戏引擎中网络游戏的基础

一、前言

网络游戏所面临的挑战:

  • 一致性:如何在所有的主机内都保持一样的表现
  • 可靠性:网络传输有可能出现丢包
  • 安全性:反作弊,反信息泄漏。
  • 多样性:不同设备之间链接,比如手机,ipad,电脑等设备,热更新逻辑。
  • 复杂性:高并发,高效率,高表现。

二、网络协议

Vint Cerf和Robert Kahn设计了TCP/IP协议用于在不同主机之间传递信息。

 2.1 OSI七层网络

需要详细了解,可以去我的计算机网络专栏查看。

2.2 Socket

通过socket接口就可以和别的主机建立链接。

 2.3 TCP与UDP

这里详细说了,去我计算机传输层看吧。

2.4 Reliable UDP

网络游戏:基于UDP的可靠网络连接。

TCP传输可靠但是太慢了,UDP很快,但是他不保证可靠传输,很容易丢包。所以我们需要在UDP上加上确认机制和重传机制等方法来保证数据的可靠传输。

2.5 FEC

在传输时传输足够数量的额外冗余信息,在一定程度上重建丢失的数据。

1. XOR-FEC

 通过异或运算求解丢失的数据。但是这个适用于丢一个包的数据,当丢多个相邻包的数据时可以用下面这个方法。

2.Reed-Solomon codes

 

三、时钟同步与RPC

在游戏开始前,需要对准所有客户端的游戏时间。

3.1 RTT

往返传输时延

3.2 NTP

与服务器对时间

NTP算法:

 

3.3 Remote Procedure call(RPC)

程序员只需要重点关注逻辑,不需要关注那么多的网络方面的。

通过在服务端定义各种方法,客户端只需要调用和传递参数即可:

 

四、网络拓扑 

4.1 P2P

4.2 Dedicatd Server

 五、游戏同步

5.1 快照同步(Snapshot Synchronization)

类似云游戏,客户端只做输入和显示,别的都交给服务器。

优化:

  • 服务端按照10fps计算,客户端按照60fps显示,多的fps进行插值。
  • 数据压缩,只发送变化的数据。

这样导致客户端的算力浪费了,并且对带宽要求很高。

5.2 帧同步(LockStep Synchronization)

类似军队中每个人步调一致的向前走,在相同的时间点,各个客户端的表现一致。

同样的输入 + 同样的处理逻辑 = 同样的表现

例如游戏中的回放并不是游戏战斗过程的录屏,而是在游戏时记录所有玩家的输入,然后将这些输入重新计算就可以得到同样的效果。

第一款使用帧同步的游戏:Doom。王者荣耀也是用帧同步做的。

帧同步的过程:每一帧所有的客户端把你输入交给服务器,服务器汇总后再发给每个客户端,每个客户端按照同样的逻辑处理这些输入。

优点:非常简单,特别公平

缺点:最慢的那个客户端会拖慢所有的客户端。

优化:不等最慢的客户端,设定一个deadline,超出deadline后就不管没有提交的输入了,而是发放已经提交的输入。 

帧同步需要让所有客户端保持一致性 :

  • 浮点数 :所有的数学运算都要符合原理。2/3在所有客户端的结果都是一样的。

  • 随机数:每个客户端生成的随机数也是一样的,使用随机种子。所以计算机生成的随机数是伪随机

  • 存储所有的数据,当游戏出现差错时可以回溯

  • 使用buffer来解决延时的问题,

  • 在逻辑帧中添加渲染帧,避免抖动。

  • 断线重连,将别人的数据存储在本地,当玩家回来后根据这些逻辑追帧。

帧同步实现反作弊面临的问题:

  • 一个客户端修改时数据后,服务端根据别的大多数客户端的数据判断,然后剔除作弊的客户端。
  • 如果只有两个客户端的话,服务器就不能判断谁在作弊了。
  • 帧同步是把所有客户端的数据都传到一个客户端进行计算,所以对于单个客户端来说很容易做一个插件让玩家知道所有人当前的状态。

优点:带宽要求小,只需要同步所有的指令。对于即时性的游戏很合适。

缺点:保持一致性面临很多挑战,难以避免全图挂。

5.3 状态同步(State Synchronization)

每个客户端提交自己的输入信息,server端会根据所有客户端输入模拟整个世界,然后将对应玩家的结果状态返回给对应玩家。注意并不是所有的状态,这里要和快照同步区分。

 玩家A的客户端状态玩家A说了算,但是在别的客户端玩家A的状态是由服务器说了算。在玩家B的客户端看到的玩家A只是玩家A的复制品,他的行为逻辑是由服务器计算反馈的。

注意哦,所有玩家对场景还是别的玩家造成的影响,无论在哪个客户端,结果都是由服务端说的算。

存在的问题:dump client problem,由于客户端的表现要受到服务端的控制,所以玩家输入后由于网络问题可能会看到延时反应的效果。

解决方法:

1.Client-side Prediction  

2.Server Reconciliation

 

 

 

相关文章:

游戏引擎中网络游戏的基础

一、前言 网络游戏所面临的挑战: 一致性:如何在所有的主机内都保持一样的表现可靠性:网络传输有可能出现丢包安全性:反作弊,反信息泄漏。多样性:不同设备之间链接,比如手机,ipad&a…...

ES6(ECMAScript 6)中常用的知识点总结(包含示例代码)

ES6(ECMAScript 6)是JavaScript语言的最新版本,它在ES5的基础上做了很多增强和扩展,使JavaScript的编程模式更加现代化和优雅,不仅拓展了语言表达能力,也为编程带来了全新的编程范式和思维方式。在项目中使用ES6,让代码更加简洁、方便模块化和面向对象实现等&#x…...

老师人手必备的教学神器有哪些?这5款教学软件一定要知道!

教师职业生活中有哪些“神器”?对老师来说堪称神器的东西有很多,笔者虽不是老师,工作内容有所不同,但工作给人带来的心力消耗(心累/压力/焦虑)、身体上的疲惫(困)等等,这…...

华为机试题-核酸检测人数

题目 为了达到新冠疫情精准防控的需要,为了避免全员核酸检测带来的浪费,需要精准圈定可能被感染的人群。现在根据传染病流调以及大数据分析,得到了每个人之间在时间、空间上是否存在轨迹的交叉。现在给定一组确诊人员编号 (X1, X2, X3, …, n…...

SQLAlchemy模型映射提示declarative_base() takes 0 positional arguments but 1 was given

原码: #SQLAlchemy模型映射表结构. from sqlalchemy import create_engine,Column,Integer,String from sqlalchemy.ext.declarative import declarative_base# 数据库的变量 HOST 127.0.0.1 PORT 3306 DATA_BASE itbz USER root PWD 123456 DB_URL fmysqlpy…...

linux系统Kubernetes工具ingress暴露服务

Ingress Ingressingress详解创建 Ingress 资源部署 Ingress 控制器(Nginx)下载ingress controller创建ingress-controller测试ingress创建两个应用和service配置ingress转发文件 修改ingress转发类型 Ingress 暴露服务基于域名的虚拟主机 Ingress 》ing…...

centos2anolis

我的centos7原地升级到anolis7记录 注意:如果是桌面版请先卸载firefox,否则so文件冲突。 参考: CentOS 7和8Linux系统迁移到国产Linux龙蜥Anolis OS 8手册_disable pam_pkcs11 module in pam configuration-CSDN博客 关于 CentOS 迁移龙蜥…...

Cesium安装部署运行

目录 1.简介 2.Cesium项目下载 3.Cesium项目运行 4.cesium运行 1.简介 Cesium是国外一个基于JavaScript编写的使用WebGL的地图引擎。Cesium支持3D,2D,2.5D形式的地图展示,可以自行绘制图形,高亮区域,并提供良好的触摸支持,且支…...

【Android 内存优化】KOOM线程泄漏监控的实现源码分析

文章目录 线程monitor的流程怎么判断线程是否泄漏AddThreadJoinThreadExitThreadDetachThread 总结 前面我们通过研究KOOM的开源代码,研究了关于Java层和native层内存泄漏监控的实现原理。还剩下线程泄漏这部分没有进行分析,今天来补全它。整体下来&…...

【爬虫基础】第1讲 网络爬虫基本知识

什么是网络爬虫 网络爬虫(Web crawler)是一种自动化程序,用于在互联网上收集信息。它可以通过扫描和解析网页的超链接,自动访问网页并抓取所需的数据。网络爬虫常用于搜索引擎和数据采集工具中。 作用 通过有效的爬虫手段批量采…...

scrapy爬虫框架

scrapy爬虫框架 一、scrapy的概念作用和工作流程1、scrapy的概念2、scrapy框架的作用3、scrapy的工作流程(重点)3.1 回顾之前的爬虫流程3.2 改写上述流程3.3 scrapy的流程3.4 scrapy的三个内置对象3.5 scrapy中每个模块的具体作用 二、scrapy的入门使用1…...

【深度学习】基础知识

吴恩达DeepLearning Python # 1.numpy c c.ravel() 将多维数组拉平 # 2.time tic time.time() toc time.time() print(str(1000*(toc- tic))"ms")...

Electron应用自动更新实现及打包部署全攻略

Electron应用自动更新实现及打包部署全攻略 Electron自动更新原理配置更新服务器打包与发布更新全攻略实战步骤部署与测试部署更新测试更新流程错误处理与调试 高级特性与优化用户体验与反馈安全与隐私保护维护与持续集成性能优化结语 在现代跨平台桌面应用开发领域中&#xff…...

【爬虫基础】第6讲 opener的使用

在爬虫中,opener是一个用来发送HTTP请求的对象。它可以用来模拟浏览器发送请求,包括设置请求头、处理Cookie等操作。使用opener可以实现一些高级功能,如模拟登录、处理验证码等。 方法1: from urllib.request import Request,bu…...

Milvus 向量数据库:如何基于docker-compose在本地快速搭建测试环境

文章目录 1. 安装 milvus1.1. milvus v2.3.12版本信息1.2. 安装milvus步骤1.3. 安装管理工具Attu1.4. 将Attu由docker-compose启动参考Milvus 向量数据库专为向量查询与检索设计,能够为万亿级向量数据建立索引,详见介绍请参见: milvus: 专为向量查询与检索设计的向量数据库 …...

python --dejavu音频指纹识别

Dejavu是一个用于音频指纹识别的Python库,它能够将音频文件转换成独特的指纹,然后通过比对数据库中已知音频的指纹,识别出输入音频的来源或相似音频。Dejavu库支持多种类型的音频文件,包括MP3、WAV等,同时也支持在不同…...

完全二叉树的层序遍历[天梯赛]

文章目录 题目描述思路 题目描述 输入样例 8 91 71 2 34 10 15 55 18 输出样例 18 34 55 71 2 10 15 91思路 完全二叉树最后一层可以不满,但上面的每一层的节点数都是满的 后序遍历的顺序为"左右根",我们可以用数组模拟完全二叉树,…...

C语言看完我这篇编译与链接就够啦!!!

1. 前言 Hello!大家好我是小陈,今天来给大家介绍最详细的C语言编译与链接。 2. 编译和链接 我们通常用的编译器,比如Visual Sudio,这样的IDE(集成开发环境)一般将编译和链接的过程一步完成,通常将这这种编译和链接合…...

【React】react 使用 lazy 懒加载模式的组件写法,外面需要套一层 Loading 的提示加载组件

react 组件按需加载问题解决 1 错误信息2 解决方案 1 错误信息 react 项目在创建 router 路由时&#xff0c;使用 lazy 懒加载时&#xff0c;导致以下报错&#xff1a; The above error occurred in the <Route.Provider> component:Uncaught Error: A component suspe…...

IDEA的Scala环境搭建

目录 前言 Scala的概述 Scala环境的搭建 一、配置Windows的JAVA环境 二、配置Windows的Scala环境 编写一个Scala程序 前言 学习Scala最好先掌握Java基础及高级部分知识&#xff0c;文章正文中会提到Scala与Java的联系&#xff0c;简单来讲Scala好比是Java的加强版&#x…...

数据库锁机制:表锁、行锁(Oracle 默认)、共享锁、排他锁、乐观锁、悲观锁、死锁、Hive 中的锁

数据库锁机制是控制并发访问数据的关键技术。本文系统介绍了锁的概念、分类和应用场景&#xff1a;1&#xff09;锁通过限制并发访问确保数据一致性&#xff0c;类比厕所门锁机制&#xff1b;2&#xff09;按粒度分为表锁&#xff08;适合批量操作&#xff09;、行锁&#xff0…...

Agent 场景落地:从概念演示到真实服务

当下 Agent 概念火热&#xff0c;但多数仍停留在实验室演示、概念展示阶段&#xff1a;发布会效果惊艳&#xff0c;却难以真正走进银行、门店、家庭等真实服务场景&#xff0c;解决实际问题。 行业共识逐渐清晰&#xff1a;Agent 的价值不在酷炫演示&#xff0c;而在真实场景里…...

保姆级教程:用微信小程序测试号搞定getPhoneNumber功能(绕过企业认证限制)

微信小程序测试号实战&#xff1a;零成本解锁getPhoneNumber全流程指南 最近在帮朋友开发一个预约类小程序时&#xff0c;遇到了一个典型问题&#xff1a;需要获取用户手机号进行预约确认&#xff0c;但个人开发者账号无法直接调用getPhoneNumber接口。这让我想起了三年前第一次…...

终极指南:如何在ComfyUI中实现AI动作迁移与姿态控制

终极指南&#xff1a;如何在ComfyUI中实现AI动作迁移与姿态控制 【免费下载链接】ComfyUI-MimicMotionWrapper 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-MimicMotionWrapper ComfyUI-MimicMotionWrapper是一个基于腾讯MimicMotion技术的ComfyUI插件&#…...

3分钟搞定!GetQzonehistory教你永久保存QQ空间青春回忆

3分钟搞定&#xff01;GetQzonehistory教你永久保存QQ空间青春回忆 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 还在担心那些承载着青春记忆的QQ空间说说会消失吗&#xff1f;GetQzo…...

用Excel手搓反向传播神经网络:零代码理解梯度下降

1. 项目概述&#xff1a;用Excel手搓一个能反向传播的神经网络&#xff0c;真不用写一行代码你有没有过这种感觉&#xff1a;想搞懂神经网络到底是怎么“学”会识别猫狗、预测房价的&#xff0c;可一翻开教材就是矩阵求导、链式法则、张量运算&#xff0c;还没开始就卡在了数学…...

百度GEO优化是什么意思

这是很多国内企业主都会问的问题。因为在大多数人的认知中&#xff0c;“搜索百度”&#xff0c;所以一提到GEO&#xff0c;自然联想到百度。百度GEO优化&#xff0c;指的是在百度搜索引擎及其AI生态产品中&#xff0c;围绕百度AI生成的答案模块进行的品牌可见性优化。这包含两…...

观察Taotoken在多模型聚合调用下的月度账单明细

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 观察Taotoken在多模型聚合调用下的月度账单明细 对于个人开发者或项目组而言&#xff0c;在项目中集成多个大语言模型&#xff08;…...

KMS智能激活终极指南:三步永久激活Windows和Office的完整教程

KMS智能激活终极指南&#xff1a;三步永久激活Windows和Office的完整教程 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为Windows系统频繁弹出激活提示而烦恼吗&#xff1f;Office文档突然…...

智改数转:制造企业绕不开的必答题

近几年&#xff0c;"智改数转"这个词频繁出现在各地政策文件和行业论坛里。对很多制造企业来说&#xff0c;它已经从"可选项"变成了"必答题"。但真正落地的时候&#xff0c;问题远比口号复杂。先说句实话&#xff1a;多数企业的数字化还停留在表…...