异步持久化策略对比

1.背景

游戏服务器其中一项重点工作,就是对游戏玩家的数据进行持久化,保证下次登录可以再续前缘。如果游戏服务器架构里没有缓存,每次操作都需要读写数据库,无疑对数据库带来非常大的压力。一旦使用缓存,就伴随异常持久化的需求。也就是说,玩家数据先写入缓存,然后服务器在稍后的某个时候,再把数据回写到数据库。

这里的“某个时候”,就有几种策略。

排队策略:采用“先进先出”的策略,排在前面的数据先入库,多次操作去重。

延迟策略:先拿个号,XX时间后,再入库,期间的多次操作直接进行数据合并。

定时策略:基于cron表达,例如每隔五分钟,将排队的所有数据批量更新。

2.代码实现

2.1.实体接口

说实在,加这个接口多少带点无奈,因为加了就强迫用户的领域类实现该接口,对用户的现有代码造成了入侵。但是不加这个,又无法解决一个难题。当用户引入了Redis等进程外缓,每次从Redis读取的数据都是重新序列化的。持久化容器没办法判断前后两个对象是不是同一个对象。

所以这个接口的唯一目的,就是提供一个getId()接口,以便容器能够去重。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jforgame

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值