Redis/MongoDB 接口封装(C++)

上传者: kamikameha | 上传时间: 2021-07-01 17:17:59 | 文件大小: 376KB | 文件类型: RAR
最近重构并优化了一套后端服务的代码: 1. 设计并开发高效的C++对象池算法,时间复杂度为 O(1) 在整个重构框架中,对象池是负责管理内存的底层基本模块 2. 利用命令模式的思想开发 Redis 子模块 抽象出方便高效的接口提供给上层程序员使用 3. 利用组合模式和装饰模式的思想开发 MongoDB 数据库查询条件装饰器 将查询条件和数据库 MongodbModule 数据模型进行解耦合 4. 抽象出一套 MongoDB Module 结果集接口 通过模板和特化技术实现 string/int 等不同索引类型的结果集 5. 开发 AbstractMongodbModule 类处理通用的 MongoDB 数据库表数据操作 数据库中不同的表都有自己的 AbstractMongodbModule 子类对应 6. 用 Perl 开发自动代码生成器,上层程序员对照数据库表结构写 .tmpl 配置文件, 自动生成该数据库表的 MongodbModule 子类,减轻程序员新增表时的工作量 7. 结合 Redis 模块和 MongoDB 模块,开发 HierarchicalModule 分层数据模型 构造一个 Redis 缓存层 + MongoDB 持久层的后台 Server 架构 并通过简单方便的接口供上层程序员使用,具体的数据分层处理对上层程序员是黑盒的 8. 设计并开发整套缓存层使用的 KEY 规则,方便缓存更新 结合公司的数据订阅系统进行 Redis缓存层 + MongoDB 持久层数据更新功能 9. 重构后的分层数据架构比原有接口效率提高 5 - 400 倍(返回数据记录条数从 150 - 5 条) 绝大部分时间后端接口需要获取记录个数在 50 以内,所以效率提升在 100 倍左右

文件下载

资源详情

[{"title":"( 104 个子文件 376KB ) Redis/MongoDB 接口封装(C++)","children":[{"title":"redis_transaction.h <span style='color:#111;'> 1.55KB </span>","children":null,"spread":false},{"title":"redis_transaction.cpp <span style='color:#111;'> 3.99KB </span>","children":null,"spread":false},{"title":"redis_conn_pool.h <span style='color:#111;'> 2.13KB </span>","children":null,"spread":false},{"title":"redis_conn_pool.cpp <span style='color:#111;'> 7.93KB </span>","children":null,"spread":false},{"title":"redis_mutex.cpp <span style='color:#111;'> 8.71KB </span>","children":null,"spread":false},{"title":"......","children":null,"spread":false},{"title":"<span style='color:steelblue;'>文件过多,未全部展示</span>","children":null,"spread":false}],"spread":true}]

评论信息

  • netanimals :
    不错,分层模型可以参考。
    2019-06-01
  • syts666 :
    很好,省了很多时间,谢谢
    2019-03-22
  • zhouqing19860311 :
    感谢分享!!!
    2018-01-24
  • barry_di :
    下载的丢了,想再下载一次
    2018-01-02
  • oouup :
    写的还可以,文档挺全的,正在研究如何使用。
    2016-05-23

免责申明

【只为小站】的资源来自网友分享,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,【只为小站】 无法对用户传输的作品、信息、内容的权属或合法性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论 【只为小站】 经营者是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。
本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二条之规定,若资源存在侵权或相关问题请联系本站客服人员,zhiweidada#qq.com,请把#换成@,本站将给予最大的支持与配合,做到及时反馈和处理。关于更多版权及免责申明参见 版权及免责申明