安装
下载redis 的压缩包,在linux下解压
一般将文件放在:/usr/local/redis/ 下
在src文件里,./redis-server 启动redis,
此时需要再开一个连接,才可以使用redis.
ps:查看 redis 进程
ps -aux | grep redis
C++基本操作redis(三个文件,使用Makefie生成可执行文件):
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)
{
//说明:该函数用来连接redis数据库,参数为数据库的ip地址和端口
// 一般redis数据库的端口为6379;
// 函数返回值:该函数返回一个结构体redisContext;
// 类似的提供了一个函数redisContext* redisConnectWithTimeout(const char *ip, int port, timeval tv),
// 以带有超时的方式连接 redis服务器,同时获取与redis连接的上下文对象。
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)
{
// 函数原型:void *redisCommand(redisContext *c, const char *format, ...);
// 说明:该函数执行命令,就如sql数据库中的SQL语句一样,
// 只是执行的是redis数据库中的操作命令,第一个参数为连接数据 库时返回的redisContext,
// 剩下的参数为变参,就如C标准函数printf函数一样的变参。 函数返回值:返回值为void*,
// 一般强制转换成为redisReply类型,以便做进一步处理。
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;
}