VS2017的redis客户端实现

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: VS2017的redis客户端实现

VS2017下Redis服务器源码地址

https://download.csdn.net/download/qq_23350817/88541316

VS2017下Redis客户端源码地址(hiredis已完成windows下编译):

https://download.csdn.net/download/qq_23350817/88541242

C代码实现:

#include <stdio.h> 
#include <stdlib.h> 
#include <stddef.h> 
#include <stdarg.h> 
#include <string.h> 
#include <assert.h> 
#include <hiredis.h>
void doTest()
{
  //redis默认监听端口为6387 可以再配置文件中修改 
  redisContext* c = redisConnect("10.10.0.7", 6379);
  if (c->err)
  {
    redisFree(c);
    printf("Connect to redisServer faile\n");
    return;
  }
  // 进行身份验证(用户名和密码)
  redisReply *reply = (redisReply *)redisCommand(c, "AUTH test123");  // 替换为你的 Redis 密码
  if (reply == NULL || reply->type == REDIS_REPLY_ERROR) {
    printf("Authentication failed: %s\n", reply ? reply->str : "NULL");
    freeReplyObject(reply);
    return;
  }
  freeReplyObject(reply);
  reply = redisCommand(c, "SELECT 0");
  if (reply == NULL || reply->type == REDIS_REPLY_ERROR) {
    printf("Error selecting database: %s\n", reply ? reply->str : "NULL");
    freeReplyObject(reply);
    redisFree(c);
    return;
  }
  const char* command = "get auth:third-party:token";
  redisReply* r = (redisReply*)redisCommand(c, command);
  r = (redisReply*)redisCommand(c, command);
  if (r->type != REDIS_REPLY_STRING)
  {
    printf("Failed to execute command[%s]\n", command);
    freeReplyObject(r);
    redisFree(c);
    return;
  }
  printf("The value of 'sunx' is %s\n", r->str);
  freeReplyObject(r);
  printf("Succeed to execute command[%s]\n", command);
  redisFree(c);
}
int main()
{
  doTest();
  return 0;
}
#include <stdio.h> 
#include <stdlib.h> 
#include <stddef.h> 
#include <stdarg.h> 
#include <string.h> 
#include <assert.h> 
#include <hiredis.h> 
void doTest()
{
  //redis默认监听端口为6387 可以再配置文件中修改 
  redisContext* c = redisConnect("10.100.0.127", 6379);
  if (c->err)
  {
    redisFree(c);
    printf("Connect to redisServer faile\n");
    return;
  }
  printf("Connect to redisServer Success\n");
  const char* command1 = "set sunx 123456789";
  redisReply* r = (redisReply*)redisCommand(c, command1);
  if (NULL == r)
  {
    printf("Execut command1 failure\n");
    redisFree(c);
    return;
  }
  if (!(r->type == REDIS_REPLY_STATUS && strcmp(r->str, "OK") == 0))
  {
    printf("Failed to execute command[%s]\n", command1);
    freeReplyObject(r);
    redisFree(c);
    return;
  }
  freeReplyObject(r);
  printf("Succeed to execute command[%s]\n", command1);
  const char* command2 = "strlen sunx";
  r = (redisReply*)redisCommand(c, command2);
  if (r->type != REDIS_REPLY_INTEGER)
  {
    printf("Failed to execute command[%s]\n", command2);
    freeReplyObject(r);
    redisFree(c);
    return;
  }
  int length = r->integer;
  freeReplyObject(r);
  printf("The length of 'sunx' is %d.\n", length);
  printf("Succeed to execute command[%s]\n", command2);
  const char* command3 = "get sunx";
  r = (redisReply*)redisCommand(c, command3);
  if (r->type != REDIS_REPLY_STRING)
  {
    printf("Failed to execute command[%s]\n", command3);
    freeReplyObject(r);
    redisFree(c);
    return;
  }
  printf("The value of 'sunx' is %s\n", r->str);
  freeReplyObject(r);
  printf("Succeed to execute command[%s]\n", command3);
  const char* command4 = "get test";
  r = (redisReply*)redisCommand(c, command4);
  if (r->type != REDIS_REPLY_NIL)
  {
    printf("Failed to execute command[%s]\n", command4);
    freeReplyObject(r);
    redisFree(c);
    return;
  }
  printf("The value of 'test' is %s\n", r->str);
  freeReplyObject(r);
  printf("Succeed to execute command[%s]\n", command4);
  redisFree(c);
}
int main()
{
  doTest();
  return 0;
}

C++代码实现:

#include <iostream>
#include <string>
#include <winsock2.h>
extern "C" {
#include <hiredis.h>
}
#pragma comment(lib, "hiredis.lib")
#pragma comment(lib, "Win32_Interop.lib")
std::string GetToken()
{
  std::string strToken = "";
  std::string ipaddr = "10.100.0.127";
  int port = 6379;
  struct timeval timeout = { 5, 0 }; // 设置超时时间为 5 秒
  std::string password = "hlxredis";
  std::string setPasswdCmd = "AUTH " + password;
  std::string tokenKey = "auth:third-party:token";
  redisContext* c = redisConnectWithTimeout(ipaddr.c_str(), port, timeout);
  if (c->err)
  {
    redisFree(c);
    printf("Connect to redisServer faile\n");
    return strToken;
  }
  redisReply *reply = (redisReply *)redisCommand(c, setPasswdCmd.c_str());
  if (reply == NULL || reply->type == REDIS_REPLY_ERROR) {
    printf("Authentication failed: %s\n", reply ? reply->str : "NULL");
    freeReplyObject(reply);
    return strToken;
  }
  freeReplyObject(reply);
  std::string selectDbCmd = "SELECT 0";
  reply = (redisReply *)redisCommand(c, selectDbCmd.c_str());
  if (reply == NULL || reply->type == REDIS_REPLY_ERROR) {
    printf("Error selecting database: %s\n", reply ? reply->str : "NULL");
    freeReplyObject(reply);
    redisFree(c);
    return strToken;
  }
  std::string getTokenCmd = "get " + tokenKey;
  redisReply* r = (redisReply*)redisCommand(c, getTokenCmd.c_str());
  if (r->type != REDIS_REPLY_STRING)
  {
    printf("Failed to execute command[%s]\n", getTokenCmd.c_str());
    freeReplyObject(r);
    redisFree(c);
    return strToken;
  }
  strToken = r->str;
  printf("The value of 'sunx' is %s\n", r->str);
  freeReplyObject(r);
  printf("Succeed to execute command[%s]\n", getTokenCmd.c_str());
  redisFree(c);
  return strToken;
}
int main()
{
  std::cout << "token:" << GetToken() << std::endl;;
  return 0;
}

注意:C++代码实现时,VS2017可能会报错检测到“RuntimeLibrary”的不匹配项: 值“MT_StaticRelease”不匹配值“MD_DynamicRelease”,此时需要如下修改:

运行结果如下:

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
2月前
|
JSON NoSQL Java
【Redis】2、Redis 的 Java 客户端(Jedis 和 SpringDataRedis)
【Redis】2、Redis 的 Java 客户端(Jedis 和 SpringDataRedis)
45 0
|
7月前
|
NoSQL 安全 Go
Golang 官方推荐使用的 Redis 客户端 redigo
Golang 官方推荐使用的 Redis 客户端 redigo
133 0
|
5月前
|
NoSQL 安全 Java
Redis基础篇:Redis的Java客户端
Redis基础篇:Redis的Java客户端
|
2月前
|
NoSQL Redis
Netty实战:模拟Redis的客户端
Netty实战:模拟Redis的客户端
14 0
|
2月前
|
存储 缓存 Dragonfly
微软开抢年收入上亿美元的 Redis 饭碗?开源性能遥遥领先的 Garnet:无需修改,Redis 客户端可直接接入
微软开源了高性能缓存系统Garnet,旨在挑战 Redis 和 Dragonfly。Garnet 基于 .NET8,提供高吞吐量、低延迟和跨平台支持。它支持 RESP 协议,允许大部分 Redis 客户端无缝迁移。Garnet 的特性包括多连接批量处理以提升扩展性和吞吐量,以及更好的延迟稳定性。适合于需要高性能缓存层来降低成本和提高应用性能的场景。Garnet 的集群模式允许动态键迁移和分片管理,且支持 TLS 和自定义扩展。其网络层设计减少了线程切换开销,存储层则具备丰富的 API 和事务支持。在基准测试中,Garnet 在吞吐量和延迟上优于 Redis 和 KeyDB,展现出优秀的扩展性。
315 0
微软开抢年收入上亿美元的 Redis 饭碗?开源性能遥遥领先的 Garnet:无需修改,Redis 客户端可直接接入
|
2月前
|
存储 NoSQL Redis
Star 3.1k!Tiny RDM 刚上线就收获一众好评的Redis桌面客户端!现代化、轻量级、跨平台!
Star 3.1k!Tiny RDM 刚上线就收获一众好评的Redis桌面客户端!现代化、轻量级、跨平台!
|
5月前
|
JSON NoSQL Java
⑩【Redis Java客户端】:Jedis、SpringDataRedis、StringRedisTemplate
⑩【Redis Java客户端】:Jedis、SpringDataRedis、StringRedisTemplate
30 0
|
5月前
|
JSON NoSQL Java
redis笔记 二 redis客户端Jedis使用(二)
redis笔记 二 redis客户端Jedis使用
38 0
|
5月前
|
设计模式 NoSQL Java
redis笔记 二 redis客户端Jedis使用(一)
redis笔记 二 redis客户端Jedis使用
51 0
|
6月前
|
缓存 NoSQL 大数据
4款.NET开源的Redis客户端驱动库
4款.NET开源的Redis客户端驱动库