NoSql-C/C++操作Redis

前面我们介绍了这么多今天我们一起来用C/C++操作一下redis数据库,后面我们在介绍redis更多高级的东西。现在我们先来连上操作试试感觉怎么样再说。

我们需要一个 开源的hiredis:https://github.com/redis/hiredis  这里的封装大家可以直接来用

介绍一些常用的函数:

1. redisContext* redisConnect(const char *ip, int port)

  该函数用来连接redis数据库, 两个参数分别是redis数据库的ip和端口,端口号一般为6379。类似的还提供了一个函数,供连接    超   时限定,即

  redisContext* redisConnectWithTimeout(const char *ip, int port, timeval tv)。

  前面文章在讲 alarm的时候已经介绍 了 这个 timeval,这里我就不做过多的解释了

2. void *redisCommand(redisContext *c, const char *format...)

   该函数用于执行redis数据库中的命令,第一个参数为连接

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.什么是外存Exist 外存本质上是一个内存级别的nosql。 它提出了“面向变量”的数据访问思想,让用户只见变量,不见接口,省去了繁琐的接口调用。以此实现了逻辑与数据分离的效果,一份单结点代码自动达到分布式效果。目前提供了int8、uint8、uint64、float、double等基础类型变量的操作,后续将实现map vector类型变量操作。2.应用场景对比来看看面向变量的接口方式比传统数据接口方式要方便多少场景1:假设服务上有3个逻辑:用户登录时,用户发表文章,用户发表评论时,要提升用户等级 。传统数据库接口方式 申明数据库连接 db; db.connect(); OnLogin() {     申明变量 level     get(表名,"level", level);     level ;     set(表名,"level", level); } OnSend() {     申明变量 level     get(表名,"level", level);     level     set(表名,"level", level); } OnReply() {     申明变量 level     get(表名,"level", level);     level     set(表名,"level", level); } 面向变量的访问方式 Exist::int32 m_var("level");//申明变量 OnLogin() {     var ;//数据已经在外存服务器上修改,下次访问将在新值基础上 } OnSend() {     var ;//数据已经在外存服务器上修改,下次访问将在新值基础上 } OnReply() {     var ;//数据已经在外存服务器上修改,下次访问将在新值基础上 }就这么简单,用户直接看到一个个的变量,就像操作内存上的变量一样操作数据,根本不需要任何接口,外存由此得名场景2:100万用户同时在线:用户A要查询用户B的资料传统接口方式m_otherNode;//其它结点/中转定位服务 std::map<...> m_userList;//已经登录当前结点的用户的列表 OnFindUser( char *username ) {         map::iterater it = m_userList.find(username);         if ( it == m_userList.end() )//用户未必再当前结点登录,         {                 m_otherNode.Send("查询用户数据");//到其它结点,或其它定位服务中专查询                 m_otherNode.Recv();                 if (回应用户不存在)                  {                         回应用户不存在;                         return;                 }         }         回应用户信息         return; };面向变量接口方式Exist::map<...> m_userList;//已经登录的用户的列表,用户信息在外存上 OnFindUser( char *username ) {         map::iterater it = m_userList.find(username);         if ( it == m_userList.end() )//用户要么在外存中,要么不存在         {                 回应,用户不存在;                 return;         }         回应用户信息;         return; };省去了到其它结点查询的代码,省去了记录相关服务的连接对象,一套代码同时满足单结点与分布式需求,从此没有分布式一说map与vector尚未实现,将在后续版本中实现,请期待支持平台:win linux性能:单个client测试,win 5000~6000tps,linux 最高达到3.7万tps支持编译:VC 6.0和VS2010,VS2010以下用户可以从 VC6.0工程转换,linux直接make欢迎各路朋友一起体验尝鲜 标签:外存  NoSQL数据库

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值