从游戏开发到应用开发的转变

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介:

     从2011年大学毕业到2014年年底,这段时间我的软件开发生涯是在游戏圈子里渡过的,虽然终究并没有做出什么名堂来,但是至少也是混到了服务器主程的位置;游戏开发的那些日子,大概也是进步最快的日子,回忆起来自己的博客里面比较有质量的文章都是那段时间写的,尤其是面对上线和大并发的时候,对于软件和代码的理解有了不同于刚毕业那会的理解,我想大概也是项目推动成长吧!

     时间来到了2014年年底,随着自己对于游戏开发的兴趣骤减和于策划方案冲突的急剧加深,慢慢产生了离开这个行业的想法,于是就在那个契机,自己放下了一切切入到了应用的开发!

     记得第一个应用是一个手机端的应用,大概是一个类似于微博那样的应用,当然功能要弱化的多;简单被带着入门app端之后,发现服务器端的逻辑完全无法入手;最后也是在网上抄了一个redis的微博的例子;在这个例子的基础之上开做起来了。那个应用的数据库没有使用mysql,而是直接使用的redis,现在无论如何我也不会这样了吧。没有用mysql也主要是因为自己对于mysql的不熟悉,做游戏的时候对于数据库的使用处于全部nosql或者简单mysql的状态。比如我们只会设计一个玩家表,可能很多人要说玩家不是很多属性吗?一个表怎么够用,其实我们是把很多玩家的数据全部封装成json,base64转换,zip压缩,已text形式保存到mysql的表中。这样几乎mysql中两三个表就能保存游戏中所有的数据;可是到了应用层则就不一样了,一个微商城都几乎使用近一百个表,还要处理个个表之间的关系,试图等等。

      做游戏服务器的时候,写逻辑几乎不与数据库打交道,而现在写应用却几乎很难离开数据库。写游戏的时候,比如做一个帮战系统,进入到帮战里面所有的人,都是登录玩家,玩家数据已经全部加载到内存中,和他交互或者的其他玩家都是这个场景内的其他的玩家,数据也早已经加载到内存中,任何一个打斗,交互,移动等逻辑处理,都是处理内存中数据和逻辑。做应用就不一样了,应用中用户之间交互的载体变成了数据库,而不再是内存,如果用户A想要得到用户B的行为,那么用户B的行为首要要被存储到数据库中。这一点是在从游戏服务器转向webapp的过程中最痛苦的也是最难理解的,至少我个人是这个情况。记得自己第一个php小应用,把MySQL的连接做成了全局变量;以为这样每个连接都能共享;知道后来发生了mysql连接不够用的情况。

      对于游戏来讲,数据库只是一个玩家下线暂存玩家数据的地方;也就是说并不是重中之重;而对于应用来讲则不一样了;数据库除了保存着应用所有的数据,还可以用来驱动逻辑,比如触发器,游标,等等。比如排行使用order等。所以这造就了游戏程序员看到一个业务或者模块,首先想到使用怎么样的数据结构。而对于应用程序员看到了一个业务和模块首先想到了是如何设计数据库;我现在看到了很多应用开发者再处理一个逻辑的时候,首先想到的并不是从数据结构上做文章;而是首先改变数据表设计。对于游戏程序员来讲,似乎天生的拒绝多哪怕一次的sql操作,能在内存中解决的,不在数据库中做。

      在做游戏开发的时候,是把nosql作为主数据库设计的,在我开发游戏的前两年,都是用mongo作为主要的数据库;但是到了应用上,nosql还是用来作为一些特定模块的解决方案,或者是为了缓存一些常用数据。比如商城系统,对于经常游览的商品,我们就把它保存到redis中,对于首页,我们也直接将首页的html+css数据保存到redis中;但是在应用中把nosql作为主数据库,遇到复杂的逻辑,比如商品销量统计或者订单统计之类的需求,用redis就勉为其难了。

      软件开发是一个行业,可是这个行业内不同应用层之间也似乎像是隔山似的,有着不同的开发原则和准绳;我们从一个应用层到另一个应用层,也应该抱着谦卑的姿态,首先做到融入,再熟悉,然后再想着发挥自己的才能才好!

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
kde
|
6天前
|
Docker镜像加速指南:手把手教你配置国内镜像源
配置国内镜像源可大幅提升 Docker 拉取速度,解决访问 Docker Hub 缓慢问题。本文详解 Linux、Docker Desktop 配置方法,并提供测速对比与常见问题解答,附最新可用镜像源列表,助力高效开发部署。
kde
3829 8
国内如何安装和使用 Claude Code镜像教程 - Windows 用户篇
国内如何安装和使用 Claude Code镜像教程 - Windows 用户篇
661 1
Dify MCP 保姆级教程来了!
大语言模型,例如 DeepSeek,如果不能联网、不能操作外部工具,只能是聊天机器人。除了聊天没什么可做的。
1008 11
【保姆级图文详解】大模型、Spring AI编程调用大模型
【保姆级图文详解】大模型、Spring AI编程调用大模型
435 7
【保姆级图文详解】大模型、Spring AI编程调用大模型
2025年最新版最细致Maven安装与配置指南(任何版本都可以依据本文章配置)
本文详细介绍了Maven的项目管理工具特性、安装步骤和配置方法。主要内容包括: Maven概述:解释Maven作为基于POM的构建工具,具备依赖管理、构建生命周期和仓库管理等功能。 安装步骤: 从官网下载最新版本 解压到指定目录 创建本地仓库文件夹 关键配置: 修改settings.xml文件 配置阿里云和清华大学镜像仓库以加速依赖下载 设置本地仓库路径 附加说明:包含详细的配置示例和截图指导,适用于各种操作系统环境。 本文提供了完整的Maven安装和配置
2025年最新版最细致Maven安装与配置指南(任何版本都可以依据本文章配置)
|
3天前
typora免费版,激活方法,Typora使用教程
Typora是一款简洁高效的Markdown编辑器,支持即时渲染。本教程涵盖安装方法、文件操作、视图控制、格式排版、字体样式及Markdown语法,助你快速上手使用Typora进行高效写作。
693 0
Excel数据治理新思路:引入智能体实现自动纠错【Python+Agent】
本文介绍如何利用智能体与Python代码批量处理Excel中的脏数据,解决人工录入导致的格式混乱、逻辑错误等问题。通过构建具备数据校验、异常标记及自动修正功能的系统,将数小时的人工核查任务缩短至分钟级,大幅提升数据一致性和办公效率。
让AI时代的卓越架构触手可及,阿里云技术解决方案开放免费试用
阿里云推出基于场景的解决方案免费试用活动,新老用户均可领取100点试用点,完成部署还可再领最高100点,相当于一年可获得最高200元云资源。覆盖AI、大数据、互联网应用开发等多个领域,支持热门场景如DeepSeek部署、模型微调等,助力企业和开发者快速验证方案并上云。
334 23
让AI时代的卓越架构触手可及,阿里云技术解决方案开放免费试用
企业如何用Data Agent实现数据价值效率的飞跃
在数字化转型背景下,数据被视为“新时代的石油”,但多数企业仍面临数据价值难以高效挖掘的困境。文章深入剖析了当前数据分析中存在的“被动响应”模式及其带来的四大挑战,并提出通过Data Agent实现主动智能与数据分析民主化的新路径。Data Agent基于大语言模型和强化学习技术,具备理解、思考与行动能力,能够从“人找数据”转变为“数据找人”,推动数据洞察从专业人员走向全员参与。
DeepSeek R1+Open WebUI实现本地知识库的搭建和局域网访问
本文介绍了使用 DeepSeek R1 和 Open WebUI 搭建本地知识库的详细步骤与注意事项,涵盖核心组件介绍、硬件与软件准备、模型部署、知识库构建及问答功能实现等内容,适用于本地文档存储、向量化与检索增强生成(RAG)场景的应用开发。
413 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问