redis数据库 C++封装

前言

Redis是一种内存数据库,常用做Cache缓存使用,内置常用的五种数据结构:

  • String
  • List
  • Hashmap
  • Set
  • Zset

Linux下安装redis

在 Ubuntu 系统安装 Redis 可以使用以下命令:

$sudo apt-get update
$sudo apt-get install redis-server

启动 Redis

$ redis-server

查看 redis 是否启动?

$ redis-cli --raw

raw的作用是让中文能够正确显示出来。
以上命令将打开以下终端:

redis 127.0.0.1:6379>
127.0.0.1 是本机 IP ,6379 是 redis 服务端口。现在我们输入 PING 命令。

redis 127.0.0.1:6379> ping
PONG
以上说明我们已经成功安装了redis。


redis基本数据类型

通过这一片文章:https://www.runoob.com/redis/redis-data-types.html
可以了解到redis的基本数据类型。


redis进行C++封装

C++连接redis数据库需要使用 hiredis 库,可以从github上面直接下载。

git clone https://github.com/redis/hiredis
cd hiredis
make 
sudo make install(复制生成的库到/usr/local/lib目录下)
sudo ldconfig /usr/local/lib

安装好动态链接库之后,只需要加上 #include <hiredis/hiredis.h> 头文件;
并且在编译时加上 -lhiredis 即可连接到redis库。

下面是可以对Redis进行CRUD操作的C++源码:

github:https://github.com/Worthy-Wang/MyRedis

可以先看一下头文件,与Redis数据库实际操作完美契合。


#ifndef C_MY_REDIS_H
#define C_MY_REDIS_H
#include <string.h>
#include <hiredis/hiredis.h>
#include "C_Error.h"
using std::
最近重构并优化了一套后端服务的代码: 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 倍左右
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值