游戏中线上已有功能迭代的兼容问题

2024-03-24 07:20

本文主要是介绍游戏中线上已有功能迭代的兼容问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在游戏开发过程中,难免会有对线上已有功能进行迭代优化的需求。站在后端的角度来看,难点在于,如何在保证不会影响到用户的前提下,顺利进行对功能的升级和优化。关键在于兼容。

兼容分为功能配置、代码、用户数据和接口的兼容性。

一般来说,优先考虑的是新的代码能够兼容老的配置、老的用户数据和老的接口,这样能保证用户数据和旧版本的客户端也能正常使用。

如果是服务器是停服升级,那么只需要考虑新代码兼容老的用户数据便可。

如果服务器使用的是滚动升级,需要考虑的问题就比较多了,在前者基础上,还要考虑老代码对新的用户数据、新的配置和新的接口的兼容性,因为滚动升级过程中,玩家有可能会在已更新的服务器和未更新的服务器上来回切换。因此,在实际开发中,兼容性问题往往需要在开发功能的迭代部分时就考虑到,优先功能的实现,再对不能兼容的进行取舍。

配置方面,考虑是使用 JSON 的情况下,字段可以直接新增,如果要修改或删除字段,最好是新增一份配置,使得新配置和老配置共存。等到线上全局更新完之后,旧配置才可以废弃。

用户数据方面,一般来说用户数据都是需要保留的,特别是付费的活动。所以对于用户数据而言,兼容是最为重要的。如果没办法新老数据直接兼容?需要采取别的手段,例如把新数据存储在另外一张表,并在功能的迭代内容上线时,通过代码把旧数据转换成新数据,后续新代码直接使用新数据。

接口方面,如果前后端使用的是 Protobuf,则会有以下注意事项:

  1. 只能删除 optional 的字段,且字段序号后面不能再使用。一般来说字段可以保留不同,但不建议删除字段。
  2. 新增字段只能新增 optional、repeat 类型或者具有默认值的字段。
  3. 字段名称可以修改,但是字段序号不能修改,数据类型也只能升级,例如 int32 升级为 int64。
    如果功能实现上无法做到兼容,那么可能就要找关掉旧功能一段时间,等完全更新好线上服务器后,再开启迭代后的功能,并同步旧数据到新数据。

这篇关于游戏中线上已有功能迭代的兼容问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/840855

相关文章

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Python的time模块一些常用功能(各种与时间相关的函数)

《Python的time模块一些常用功能(各种与时间相关的函数)》Python的time模块提供了各种与时间相关的函数,包括获取当前时间、处理时间间隔、执行时间测量等,:本文主要介绍Python的... 目录1. 获取当前时间2. 时间格式化3. 延时执行4. 时间戳运算5. 计算代码执行时间6. 转换为指

Android实现两台手机屏幕共享和远程控制功能

《Android实现两台手机屏幕共享和远程控制功能》在远程协助、在线教学、技术支持等多种场景下,实时获得另一部移动设备的屏幕画面,并对其进行操作,具有极高的应用价值,本项目旨在实现两台Android手... 目录一、项目概述二、相关知识2.1 MediaProjection API2.2 Socket 网络

Redis消息队列实现异步秒杀功能

《Redis消息队列实现异步秒杀功能》在高并发场景下,为了提高秒杀业务的性能,可将部分工作交给Redis处理,并通过异步方式执行,Redis提供了多种数据结构来实现消息队列,总结三种,本文详细介绍Re... 目录1 Redis消息队列1.1 List 结构1.2 Pub/Sub 模式1.3 Stream 结

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

Android实现悬浮按钮功能

《Android实现悬浮按钮功能》在很多场景中,我们希望在应用或系统任意界面上都能看到一个小的“悬浮按钮”(FloatingButton),用来快速启动工具、展示未读信息或快捷操作,所以本文给大家介绍... 目录一、项目概述二、相关技术知识三、实现思路四、整合代码4.1 Java 代码(MainActivi

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t