使用C语言连接Redis数据库

Redis是一个开源的高性能内存数据结构存储系统,支持多种数据结构,如字符串、哈希、列表、集合等。Redis也可以通过网络进行访问,并提供了多种编程语言的接口。

本文主要介绍使用C语言连接Redis数据库,实现读写数据的操作。首先需要安装Redis数据库和hiredis库。hiredis是一个使用C语言编写的Redis客户端库,支持同步和异步方式进行访问。其中,同步方式是指客户端发送请求后,一直等待服务器的响应才继续执行下一条指令;而异步方式是指客户端发送请求后,服务器响应后再通知客户端执行下一条指令。

需要连接Redis数据库。连接Redis数据库需要先创建一个Redis上下文对象,然后使用hiredis库提供的redisConnect函数连接数据库。如果连接成功,函数返回Redis连接对象;如果连接失败,函数返回NULL。示例代码如下:

#include #include #include redisContext *redis_connect(const char *hostname, int port) {    struct timeval timeout = { 1, 500000 }; // 1.5 seconds    redisContext *context = redisConnectWithTimeout(hostname, port, timeout);    if (context == NULL || context->err) {        if (context) {            fprintf(stderr, "Redis connection error: %s\n", context->errstr);            redisFree(context);        } else {            fprintf(stderr, "Redis connection error: can't allocate redis context\n");        }        return NULL;    }    return context;}

接下来,可以使用Redis连接对象进行数据的读写操作。例如,可以使用hiredis库提供的redisCommand函数执行Redis指令。redisCommand函数的参数为Redis连接对象和Redis指令,返回类型为redisReply,表示服务器响应的结果。redisReply包含多种类型的数据,例如字符串、整数、数组等。可以根据Redis指令的返回值类型,使用redisReply中提供的函数获取具体的返回值。示例代码如下:

redisReply *redis_command(redisContext *context, const char *cmd) {    redisReply *reply = redisCommand(context, cmd);    if (reply == NULL) {        fprintf(stderr, "Redis command error: %s\n", context->errstr);    }    return reply;}

在读写数据时,需要使用Redis数据结构中提供的键值对进行操作。Redis使用字符串作为键,可以使用Redis指令SET和GET进行字符串的读写操作。示例代码如下:

void redis_set(redisContext *context, const char *key, const char *value) {    char *cmd = malloc(strlen(key) + strlen(value) + 10);    sprintf(cmd, "SET %s %s", key, value);    redisReply *reply = redis_command(context, cmd);    free(cmd);    freeReplyObject(reply);}char *redis_get(redisContext *context, const char *key) {    char *cmd = malloc(strlen(key) + 5);    sprintf(cmd, "GET %s", key);    redisReply *reply = redis_command(context, cmd);    free(cmd);    char *value = NULL;    if (reply != NULL && reply->type == REDIS_REPLY_STRING) {        value = strdup(reply->str);    }    freeReplyObject(reply);    return value;}

除了使用SET和GET进行字符串的读写操作外,Redis还提供了多种数据结构的操作,例如哈希、列表、集合等。可以根据具体的业务需求使用不同的Redis指令进行读写操作。示例代码如下:

void redis_hset(redisContext *context, const char *key, const char *field, const char *value) {    char *cmd = malloc(strlen(key) + strlen(field) + strlen(value) + 20);    sprintf(cmd, "HSET %s %s %s", key, field, value);    redisReply *reply = redis_command(context, cmd);    free(cmd);    freeReplyObject(reply);}char *redis_hget(redisContext *context, const char *key, const char *field) {    char *cmd = malloc(strlen(key) + strlen(field) + 10);    sprintf(cmd, "HGET %s %s", key, field);    redisReply *reply = redis_command(context, cmd);    free(cmd);    char *value = NULL;    if (reply != NULL && reply->type == REDIS_REPLY_STRING) {        value = strdup(reply->str);    }    freeReplyObject(reply);    return value;}void redis_lpush(redisContext *context, const char *key, const char *value) {    char *cmd = malloc(strlen(key) + strlen(value) + 10);    sprintf(cmd, "LPUSH %s %s", key, value);    redisReply *reply = redis_command(context, cmd);    free(cmd);    freeReplyObject(reply);}char *redis_rpop(redisContext *context, const char *key) {    char *cmd = malloc(strlen(key) + 10);    sprintf(cmd, "RPOP %s", key);    redisReply *reply = redis_command(context, cmd);    free(cmd);    char *value = NULL;    if (reply != NULL && reply->type == REDIS_REPLY_STRING) {        value = strdup(reply->str);    }    freeReplyObject(reply);    return value;}void redis_sadd(redisContext *context, const char *key, const char *member) {    char *cmd = malloc(strlen(key) + strlen(member) + 10);    sprintf(cmd, "SADD %s %s", key, member);    redisReply *reply = redis_command(context, cmd);    free(cmd);    freeReplyObject(reply);}int redis_sismember(redisContext *context, const char *key, const char *member) {    char *cmd = malloc(strlen(key) + strlen(member) + 10);    sprintf(cmd, "SISMEMBER %s %s", key, member);    redisReply *reply = redis_command(context, cmd);    free(cmd);    int value = 0;    if (reply != NULL && reply->type == REDIS_REPLY_INTEGER) {        value = (int)reply->integer;    }    freeReplyObject(reply);    return value;}

除了同步方式外,hiredis库还提供了异步方式进行Redis数据库的访问。异步方式的优点是可以提高程序的响应速度,尤其是在高并发场景下。可以使用hiredis库提供的redisAsyncConnect函数连接Redis数据库,并使用redisAsyncCommand函数来发送异步指令。示例代码如下:

#include #include #include #include #include void redis_set_callback(redisAsyncContext *context, void *reply, void *privdata) {    redisReply *r = (redisReply*)reply;    if (r == NULL) {        return;    }    if (r->type == REDIS_REPLY_INTEGER) {        printf("SET OK: %lld\n", r->integer);    } else {        printf("SET ERROR: %s\n", r->str);    }}int mn(int argc, char **argv) {    struct event_base *base = event_base_new();    redisAsyncContext *context = redisAsyncConnect("127.0.0.1", 6379);    if (context == NULL || context->err) {        fprintf(stderr, "Redis connection error: %s\n", context->errstr);        return 1;    }    redisLibeventAttach(context, base);    redisAsyncCommand(context, redis_set_callback, NULL, "SET mykey myvalue");    event_base_dispatch(base);    return 0;}

总结:本文介绍了使用C语言连接Redis数据库的方法,包括同步和异步方式的操作。使用hiredis库可以方便地进行读写数据,适用于多种场景。

香港服务器首选,2H2G首月10元开通。()提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。