Redis源码的快速使用

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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值