业务、工作线程数据buff封装
1、使用c++语言,vs2019开发垮平台[windows和linux]连接MySql和redis框架。
2、使用MySql持久化玩家数据,redis做玩家数据缓存层,redis不做数据持久化。
mysql搭配redis工作效率非常高效,就好比男女搭配干活不累,没有redis,mysql也能独立
很好的完成用户读写请求。有了redis,用户访问数据的效率更高,时间更短,快速的完成
请求。
3、讲解如何保持mysql和redis数据强一致性策略,并在代码里实现。每次启动redis,使用管道技术,从mysql
批量导入活跃用户数据到redis中,并设置过期时间.
4、教程使用线程池技术,每个线程拥有自己独立的数据,线程绑定类。每一个实例就包含一个线程
每个线程数据里包含:mysql连接器、redis连接器、内存回收池、安全的串行队列、条件变量、互斥量
保证线程内的数据安全。
5、工作原理:
没有请求时,各个工作线程处于休眠状态。
有读写请求时,从线程池获取一个线程,添加读写请求,把数据推送到线程工作队列中。
然后工作线程获取队列的数据,进行串行工作任务安排,进行mysql数据库读写操作,以及redis读写数据操作,
当完成工作任务时,执行下一个工作任务,同时把处理结果推送到逻辑线程,把数据给用户。
6、用户读数据策略:用户获取数据首先是先从redis查找数据,redis查找到,
返回数据给玩家,redis查找失败,mysql中查找数据,然后写入数据到redis中,返回数据给用户。
7、用户写数据策略:用户先从redis中删除数据,然后写数据到mysql中,最后再把数据写入到redis中,保持数据一致性。
8、教程是一个干货教程,不是新手教程,mysql基础语法讲解的少,redis有讲解基础系列。
教程讲解的是如何搭建一个支持高并发,高性能的读写数据库框架,使用mysql+redis搭配的高可用、高性能框架。
如果想获得源码 请联系在线客户,联系教程作者
公开笔记对他人可见,有机会被管理员评为“优质笔记”
{{ noteEditor.content.length }}/2000
讲师收到你的提问会尽快为你解答。若选择公开提问,可以获得更多学员的帮助。
课程大纲