发布于 2015-02-04 06:31:12 | 627 次阅读 | 评论: 0 | 来源: 网友投递

这里有新鲜出炉的Redis 设计与实现(第一版),程序狗速度看过来!

Redis Key-Value数据库

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。


虽然 redis 开发库已有不少,但 C/C++ 的客户端库好用的并不多,虽然官方也提供了 C 版的客户端库,但易用性较差,而且不支持连接池功能,相对于 C/C++ 的库,JAVA 版的 jedis 要好用的多,jedis 提供了 redis 库的全命令实现,而 C/C++ 则只提供了协议级实现,使用者需要了解命令发送的格式,而且还得判断分析所接收数据的格式,使用起来非常繁琐,acl 库(跨平台网络通信与服务器框架)的作者在使用 C/C++ 版的 redis 库时也屡受摧残,于是其基于 acl 的基础库完整实现了 redis 的所有命令,该库对应于 redis 客户端命令的总共 12 个大类,150多个命令,同时为了使用方便,有的命令会因参数的变化提供多个函数方法,所以在 acl 的 redis 库中的 12 个类中,有 400 多个方法;另外,该 redis 库还提供了丰富的连接池及连接池集群管理功能,便于使用者编写高性能、高并发的应用服务。

在 acl 的 redis 库中总共有 7000+ 行源代码,2000+ 行头文件,同时每个类方法都提供了详细的中文注释;为了保证该库的健壮性,作者提供了大量的测试用例(光测试用例源码就达 5000+ 行。

在 acl 的 redis 库的内部实现中,为了保证处理效率,在每一个命令处理过程中都会绑定一个内存分配器,大大减少了内存的分配/释放次数,非常适合于多线程运行环境。

下面是一个使用 REDIS HMSET 客户端命令的简单例子:

static acl::string __keypre("hash_test_key");

static bool test_hmset(acl::redis_hash& option, int n)
{
        acl::string key, attr1, attr2, attr3;
        acl::string val1, val2, val3;
        std::map<acl::string, acl::string> attrs;

        for (int i = 0; i < n; i++)
        {
                key.format("%s_%d", __keypre.c_str(), i);
                attr1.format("attr1");
                attr2.format("attr2");
                attr3.format("attr3");
                val1.format("val1_%s", attr1.c_str());
                val2.format("val2_%s", attr2.c_str());
                val3.format("val3_%s", attr3.c_str());
                attrs[attr1] = val1;
                attrs[attr2] = val2;
                attrs[attr3] = val3;

                option.reset();
                if (option.hmset(key.c_str(), attrs) == false)
                {
                        printf("hmset error, key: %srn", key.c_str());
                        return false;
                }
                else if (i < 10)
                {
                       printf("hmset ok, key: %s, %s=%s, %s=%s, %s=%srn",
                        key.c_str(), attr1.c_str(), val1.c_str(),
                        attr2.c_str(), val2.c_str(),
                        attr3.c_str(), val3.c_str());
                }
                attrs.clear();
        }

        return true;
}

该 redis 库是跨平台的,支持 LINUX/WIN32/MAC/BSD/SOLARIS,以下是有关该库的网上地址:

1、redis 库源码地址:http://git.oschina.net/zsxxsz/acl/tree/master/lib_acl_cpp/src/redis

2、redis 库头文件地址:http://git.oschina.net/zsxxsz/acl/tree/master/lib_acl_cpp/include/acl_cpp/redis

3、redis 使用例子地址:http://git.oschina.net/zsxxsz/acl/tree/master/lib_acl_cpp/samples/redis

4、该 redis 库属于 acl 项目的一部分,acl 项目的地址:http://git.oschina.net/zsxxsz/acl/tree/master



最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务