1、Redis介绍
Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。
Redis 与其他 key - value 缓存产品有以下三个特点:
(1) Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
(2) Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
(3) Redis支持数据的备份,即master-slave模式的数据备份。
2、Redis服务器
(1)、如何获取Redis服务器源码?
redis是完全开源的,官网为https://redis.io,其源代码可以在直接在官网上获取(目前最新版本是4.0.9)。执行以下指令:
root@ubuntu:~/redis# wgethttp://download.redis.io/redis-stable.tar.gz
(2)、编译Redis
make
make test
make install
(3)、启动Redis服务
在服务器路径运行/root/redis/redis-stable/src/redis-server,Redis服务启动
如何检测是否成功呢?打开另外一个终端,/root/redis/redis-stable/src下运行
[root@localhost src]# redis-cli
127.0.0.1:6379>
即连接成功
3、Redis客户端Hiredis
Hiredis 是用 C 写的 Redis客户端,对 Redis协议进行了简单的封装, 同时提供了同步和异步的两种API。Hiredis的代码位于 https://github.com/redis/hiredis。
(1)、下载hiredis并且编译
下载 https://github.com/redis/hiredis,然后上传到/root/redis目录下
make
make install
(2)、C++来操作redis数据库
如何用C++来操作redis数据库。通过hiredis.h接口来实现,目前只能在Linux环境使用。主要包括如下四个方法:
1. redisContext* redisConnect(const char*ip, int port)
该函数用来连接redis数据库, 两个参数分别是redis数据库的ip和端口,端口号一般为6379。类似的还提供了一个函数,供连接超时限定,即:
redisContext* redisConnectWithTimeout(constchar *ip, int port, timeval tv)。
2. void *redisCommand(redisContext *c,const char *format...)
该函数用于执行redis数据库中的命令,第一个参数为连接数据库返回的redisContext,剩下的参数为变参,如同C语言中的prinf()函数。函数的返回值为void*,但是一般会强制转换为redisReply类型,以便做进一步的处理。
3. void freeReplyObject(void *reply)
释放redisCommand执行后返回的的redisReply所占用的内存。
4. void redisFree(redisContext *c)
释放redisConnect()所产生的连接。
(3)、运行test例子
在使用Hiredis访问Redis服务器时候,需要首先创建了一个连接 Redis 的实例,然后通过这个连接向 Redis 发送命令。取得 Redis 的返回后,需要记住将相关的返回对象和连接对象释放,避免资源的泄漏。
新建test目录,分别创建文件redis.h,redis.cpp,Makefile
redis.h:
#ifndef _REDIS_H_
#define _REDIS_H_
#include <iostream>
#include <string.h>
#include <string>
#include <stdio.h>
#include <hiredis/hiredis.h>
class Redis
{
public:
Redis(){}
~Redis()
{
this->_connect = NULL;
this->_reply = NULL;
}
bool connect(std::string host, int port)
{
this->_connect = redisConnect(host.c_str(), port);
if(this->_connect != NULL && this->_connect->err)
{
printf("connect error: %s\n", this->_connect->errstr);
return 0;
}
return 1;
}
std::string get(std::string key)
{
this->_reply = (redisReply*)redisCommand(this->_connect, "GET %s", key.c_str());
std::string str = this->_reply->str;
freeReplyObject(this->_reply);
return str;
}
void set(std::string key, std::string value)
{
redisCommand(this->_connect, "SET %s %s", key.c_str(), value.c_str());
}
private:
redisContext* _connect;
redisReply* _reply;
};
#endif //_REDIS_H_
redis.cpp:
#include "redis.h"
int main()
{
Redis *r = new Redis();
if(!r->connect("127.0.0.1", 6379))
{
printf("connect error!\n");
return 0;
}
r->set("name", "Andy");
printf("Get the name is %s\n", r->get("name").c_str());
delete r;
return 0;
}
Makefile:
redis: redis.cpp redis.h
g++ redis.cpp -o redis -L/usr/local/lib/ -lhiredis
clean:
rm redis.o redis
make后生成redis可执行文件
[root@localhosttest]# ./redis
./redis: error while loading sharedlibraries: libhiredis.so.0.13: cannot open shared object file: No such file ordirectory
在执行的时候如果出现动态库无法加载,那么需要进行如下配置:
在/etc/ld.so.conf.d/目录下新建文件usr-libs.conf,内容是:/usr/local/lib,然后使用命令/sbin/ldconfig更新一下配置即可。
再次运行如下:
[root@localhost test]# ./redis
Get the name is Andy