本文链接:https://blog.csdn.net/BDalasja/article/details/95622429

UE4 版本迭代、资源热更、pak更新方案

注意:以下讨论的内容是客户端热更,打包的时候勾选使用pak文件

前置知识


详细可参考之前的文章 , 这里再简单回顾一下。

  1. 客户端进行打包之后,所有的资源及蓝图文件都在paks文件夹中的pak文件中。

  2. paks文件夹中所有的pak文件,会全部自动挂载。

  3. 所谓挂载,就是读取pak中的文件列表信息,并不加载实际的资源文件。实际加载文件的时候会遍历所有挂载的pak去找文件。

  4. 挂载的顺序并不是查找的顺序,每当有新文件挂载的时候,内部的pak列表会根据ReadOrder来排序。Order大的排在前面,优先被查找。

  5. ReadOrder规则:

    • Paks文件夹中,并已游戏名开头的文件起始Order为4;Content目录Order为 3 。如果paks文件夹中pak的文件名不是以游戏名为开头,则会满足Content这个条件。

    • Engine目录下的pak文件Order为2,游戏的用户存储目录则为1,其他为0 。

    • 在前两条规则的基础上,文件名以_P.pak 为结尾的,享有额外Order。额外Order最低100。如果结尾形如_n_P.pak 其中n是数字,则会再额外得到 n乘以100的Order值。 例如 _2_P.pak 则额外Order为 300 。

    • 手动mount文件时,可以指定优先级。

  6. 使用UE的ProjectLauncher工具可以打包特定版本,并可以根据前面的特定版本打包出差异补丁包。

方案思路


通过前置知识6我们知道:

使用UE的ProjectLauncher工具可以打包特定版本,并可以根据前面的特定版本打包出差异补丁包。

那么我们在发布版本1.0之后,后续的版本更新,则可以根据1.0版本的内容来产生补丁包。客户端下载该补丁包到本地的paks文件夹中,即可以完成版本的更新。下载的Pak中有最新的资源文件,现在需要解决优先加载补丁包中资源的问题。

根据前置知识 2,3,4,5,我们将patch包按一定的规则命名,例如都加上版本号_versioncode_P.pak,放入paks文件夹,可以实现特定顺序加载,优先使用新的patch中的文件。

随着版本的推进,修改的内容越来越多,可以预料到会出现的问题是:相对1.0版本生成的Patch包会越来越大。所以为了减小每次更新的大小,减少重复无用更新,在每一个、或者多个小版本之间生成patch,而不是始终相对1.0版本生成patch。多个Patch依旧使用前面的命名规则,versioncode不用,可以保证他们的优先级正确。

接下来需要自己管理一下各个版本之间的patch包的产生与下载,即可实现客户端的热更。

具体实施步骤


下面以一个实际的例子来阐述具体的热更实施流程。

首先假设前提:客户端安装包为1.0版本,后续我们陆续发布了1.1、1.2、1.3 版本的内容。

1. 1.0版本。

使用ProjectLauncher生成1.0完整包,并发布。

2. 客户端下载安装1.0版本

客户端安装1.0版本,此时项目的Paks目录下只有一个Pak及Sig文件。

3. 发布1.1版本

相对1.0版本完整包,生成1.1patch包。打包1.1的完整包,作为下次更新的参考包。

维护一个patch信息文件,比如叫 patch_list.txt,格式如下

{"suportVersion": ["1.0", "1.1"], "url":"download-url","1.1" : {"patch_10100_p.pak" : "hashcode","patch_10100_p.sig" : "hashcode"}
}

suportVersion是所有支持的客户端版本列表。如果客户端版本不在此列表中,表示客户端需要重新下载完整客户端,重新安装,适合重大或C++更新版本。

url则是文件的下载地址前缀,完整的下载地址为url与文件名的拼接,如:download-url + patch_10100_p.pak

客户端检测支持的版本号,所有大于自身版本的节点中列出的文件,都需要下载到本地paks文件夹中。并更新本地已下载pak文件信息,比如叫 local_patch_info.txt 。本地已下载pak文件的信息格式如下:

{"patch_10100_p.pak" : "hashcode","patch_10100_p.sig" : "hashcode"
}

该文件只保留已下载的pak文件及hasecode,并不需要保存版本号。客户端根据获取的patch_list.txt 和本地已下载的内容对比,形成一个下载列表。下载内容并更新本地文件。

更新结束后,客户端可以认为已经更新到版本1.1 。(只是内容更新到1.1,安装版本号还是1.0)

4. 发布版本 1.2 。 (每个小版本发布包含以下三个小步骤)

   1. 打包1.2完整包;2. 相对1.1的完整包生成1.2的patch文件;3. 更新patch_list.txt:
{"suportVersion": ["1.0", "1.1", "1.2"], "url":"download-url","1.1" : {"patch_10100_p.pak" : "hashcode","patch_10100_p.sig" : "hashcode"},"1.2" : {"patch_10200_p.pak" : "hashcode","patch_10200_p.sig" : "hashcode"},}
4.1 客户端更新流程(version 1)

现在服务器已经升级到1.2版本,客户端则可能在1.0版本,或者更新了内容的1.1版本。下面就完整说明客户端的更新流程。

  • 客户端首先获取http服务器上的patch_list.txt,根据安装版本号,计算出所有要下载的pak文件列表A。

    这个例子中,客户端安装版本号一直为1.0,则得到的文件列表为

    "1.1" :
    {"patch_10100_p.pak" : "hashcode","patch_10100_p.sig" : "hashcode"
    },
    "1.2" :
    {"patch_10200_p.pak" : "hashcode","patch_10200_p.sig" : "hashcode"
    }
    
  • 客户端检测本地local_patch_info.txt ,与列表A对比, 检查看哪些文件已下载,hasecode是否匹配,以及本地pak文件是否存在。生成最终下载列表B。

  • 客户端更新过所有内容,则跳过该步骤

  • 客户端更新过1.1的内容 则下载列表B调整为:

    "1.2" : {"patch_10200_p.pak" : "hashcode","patch_10200_p.sig" : "hashcode"}
    
  • 客户端未更新过任何内容,或者本地某pak文件的hashcode不匹配,或者pak文件缺失,则重新将此文件假如到列表B中

  • 根据下载列表B,依次下载文件。

  • 下载完成后,触发paks的加载(游戏启动之后改动的pak可能要手动触发挂载,或者触发客户端重启?需要后续再确认。) 更新本地localpatch_info.txt

5. 发布版本1.3 。本处假设1.3与1.2的内容改动不大,下列内容用于处理客户端patch的删除合并策略。

  1. 打包1.3完整包(该步骤永远需要,后续总有可能需要基于任意版本发布patch包)
  2. 相对1.1完整包来生成1.3的patch包,由于相对1.1来生成patch包,则此patch包是包含了1.2的patch包,也就是说客户端更新了此patch包,1.2的patch包就是完全多余的了,可以删除。
  3. 更新patch_list.txt
{"suportVersion": ["1.0", "1.1", "1.2", "1.3"], "url":"http://netcraft-cdn.huya.com/hotres/","1.1" : {"patch_10100_p.pak" : "hashcode","patch_10100_p.sig" : "hashcode"},"1.3" : {"patch_10300_p.pak" : "hashcode","patch_10300_p.sig" : "hashcode"},}

5.1 客户端更新流程(最终版)

对比1.2版本时的patch_list.txt,可以发现,文件节点中少1.2版本的节点。当客户端更新时,对比本地已下载的patch文件,如果存在patch_list.txt中没有的文件,则删除掉。于是客户端更新的完整流程变成:

  • 客户端首先获取http服务器上的patch_list.txt,根据安装版本号,计算出所有要下载的pak文件列表A。
  • 客户端检测本地local_patch_info.txt ,与列表A对比, 检查看哪些文件已下载,hasecode是否匹配,以及本地pak文件是否存在。生成最终下载列表B。
  • 如果local_patch_info.txt中存在列表A中不存在的文件,则删除。
  • 根据下载列表B,依次下载文件。
  • 下载完成后,触发paks的加载(游戏启动之后改动的pak可能要手动触发挂载,或者触发客户端重启?需要后续再确认。) 更新本地localpatch_info.txt

这样,就通过服务器patch_list.txt的配置,实现了对客户端多余patch文件的删除。当一些版本之外的临时更新发布后,在下次版本更新时,则可以通过patch_list修改,删除这些临时的patch文件。

6. 可能的策略

为了防止客户端pak过多(如果一个月一个版本,一年也就12个pak,其实也不多)。可以使用步骤5的方法,没隔一段时间,可以合并多个小版本的patch文件来达到这个目的。

7. 无法热更的情况

当版本发生重大变化,必须要更新C++时,则重新生成完整包,清空patch_list,重复步骤1-6 。所以尽量减少C++的改动,或者有计划的周期性改动。在游戏迭代的初期,功能不完整,可能很难做到这一点。等功能基本都完整了,只是更新一些内容玩法的时候,基本就可以不用再完整更新客户端。

http服务器的工作


  1. 上传更新patch_list.txt
  2. 上传更新个pak文件
  3. 本方案中下载服务器没有逻辑需要处理。

其他工作


需要提供工具来维护patch_list.txt ,而不是手动编辑。

目前打包和patch都是使用的ProjectLauncher工具,应该是支持指令执行的,需要进一步研究,集成到一个工具中。

该工具包含:

  1. 设置版本号
  2. 打完整包
  3. 相对某版本打patch包
  4. 勾选支持的版本号,更新patch_list.txt

参考文档


UE4资源热更新 该文章不知道作者是谁,到处都是转载的,原始链接也是错的

UE4补丁与DLC

UE4Pak相关知识总结

UE4官方打包和patch文档

UE4官方发布项目

UE4 版本迭代、资源热更、pak更新方案相关推荐

  1. UE4资源热更打包工具HotPatcher

    UE4资源热更打包工具HotPatcher https://imzlp.me/posts/17590/ Z's Blog 首页 归档 分类 标签 笔记 微言 资源 简历 关于 待办事项 站点日志 搜索 ...

  2. GameFramework:资源热更代码分析,检查版本信息,下载版本文件,校验版本文件,得到更新文件数量,下载文件,TaskPool

    资源下载流程图 流程跳转的日志 版本信息-版本检测-下载版本列表-下载散文件代码分析 进入ProcedureCheckVersion.OnEnter流程,进行task请求,userData为StarF ...

  3. 在Unity2022.3.7中集成ET 7.2 + HybridCLR 0.10.4 + XAsset 2022.2 + EUI 实现ECS编码,C#代码热更,资源热更,UI管理系统的基础框架

    工具介绍 ET 7.2  ET是一个开源的游戏客户端(基于unity3d)服务端双端框架,服务端是使用C# .net core开发的分布式游戏服务端,其特点是开发效率高,性能强,双端共享逻辑代码,客户 ...

  4. MD5校验和资源代码热更(U3D)

    MD5校验和资源代码热更(U3D) 大家都知道,做为游戏开发,现在公司肯定会问你会不会LUA,会不会热更新,等.直入主题哈,今天给大家分享一下游戏中MD5校验和资源代码热更.当然只是从服务器把资源代码 ...

  5. unity 代码热更+资源管理框架总结

    游戏要做热更涉及到什么方面呢 首先就是代码热更,然后就是资源热更 这些热更新都依赖于打AssetBundle 然而打AssetBundle 你还要上传服务器-对比更新-客户端下载-加载-卸载这些流程 ...

  6. unity python做热更_[专栏作家]基于ILRuntime的完整C#热更方案

    原标题:[专栏作家]基于ILRuntime的完整C#热更方案 好久不见.最近一段时间公司二次创业,实在是忙的脚打后脑勺,有段时间没来跟大家分享心得了,昨天终于有了一个初步的完结,也终于有时间和精力跟大 ...

  7. unity热更- 2 游戏大版本更新和热更新

    游戏上线后,遇见bug或者需要更新内容(包括资源,玩法,数值调整,游戏脚本等)的时候,一般有2种做法.第一种,发个新包,然后让玩家下载新的版本:第二种,在游戏内更新,游戏启动时去下载需要更新的资源.第 ...

  8. Unity资源热更新--资源管理、Addressable

    实习前理解错了mentor的意思,任务没完成TAT,火速学习一下addressable,另外狠狠吐槽北京健康宝弹窗. 资源打包方式 可热更资源类型:预制件.材质.贴图.模型.场景.shader.动画与 ...

  9. 《天涯明月刀》游戏资源热更新解决方案

    天刀在韩国化的过程中,韩方对天刀的游戏内商城功能提出了一系列的适应他们本土运营习惯的商业化改造需求,其中最重要的基础功能修改就是需要商城能够支持不停服修改商品内容或上下架商品,包含新增未事先打进版本配 ...

最新文章

  1. Vsftpd 服务的部署及优化
  2. Exception in thread main java.lang.Error: Unresolved compilation problem
  3. java根据日期判断星座_根据日期计算星座
  4. 报错:failed to get the task for process XXX(解决方案)
  5. mysql against包含英文_在MySQL中使用MATCH和AGAINST选择特定列中包含字符串的行
  6. python 购物车程序_Python 购物车程序(文件版)
  7. flink其他可选api
  8. 设系统中有三种类型的资源(A,B,C)的五个进程(P1,P2,P3,P4,P5)。A资源的数量为17,B资源的数量为5,C资源的数量为20。在T0时刻系统状态如表所示。
  9. 【机器学习】机器学习的主要挑战与应对方式
  10. Linux内核参数优化网络带宽,基于Linux内核的网络带宽管理
  11. 基于时间窗的AGV调度算法优化
  12. HTML|按钮和多选框
  13. iPhone 12 Pro测量人的身高竟然如此简单
  14. c语言解惑 指针 数组 函数和多文件编程,C语言解惑 指针、数组、函数和多文件编程...
  15. 四川民族学院数学系与计算机科学系,数学系、计算机科学系隆重举行学生表彰大会...
  16. react二级路由的两种方法
  17. 运行出现:Trying to start MapKit location updates without prompting for location authorization.
  18. 山东平度纵火案告破:村主任与地产商联手施暴
  19. html跳动的心,css3跳动的心制作
  20. 警告:Your CPU supports instructions that this TensorFlow binary was not compiled to use: AVX2 FMA

热门文章

  1. Mac OS制作Ubuntu安装U盘
  2. Android 动态申请应用权限
  3. blog Manager 后台管理系统
  4. linux命令pp,linux命令 $- 是什么意思
  5. 看房子软件测试初学者,新人必看,测试大佬私藏的入门性能测试五步走,果断收藏!...
  6. wireshark 学习更进一步 之wireshark异常数据解读
  7. python判断正数和负数教案_正数和负数教案(教学设计)
  8. 服务器sas卡的作用,英特尔IOP34x处理器介绍
  9. python之最大公约数
  10. python自动发送邮件不需要发件邮箱_python 自动发送邮件