Cmakelist.txt之Linux-redis配置

1.cmakelist.txt

复制代码
cmake_minimum_required(VERSION 3.16)
​
project(redis_linux_test LANGUAGES C)
​
​
​
add_executable(redis_linux_test main.c)
​
# 设置hiredis库的头文件路径和库文件路径
set(Hiredis_INCLUDE_DIR /usr/local/include/hiredis)
set(Hiredis_LIBRARY_DIR /usr/local/lib)
# 将hiredis的头文件路径添加到包含路径
include_directories(${Hiredis_INCLUDE_DIR})
# 将hiredis的库文件路径添加到库搜索路径
link_directories(${Hiredis_LIBRARY_DIR})
# 链接hiredis库到可执行文件
target_link_libraries(redis_linux_test hiredis)
​
​
include(GNUInstallDirs)
install(TARGETS redis_linux_test
    LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
    RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
)
复制代码

2.测试代码

复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <hiredis/hiredis.h>

int main()
{
    // 创建Redis连接
    redisContext *c = redisConnect("192.168.127.128", 6379);
    if (c == NULL) {
        // 如果无法分配redis上下文,直接报错并退出
        printf("Can't allocate redis context\n");
        return 1;
    } else if (c->err) {
        // 如果连接有错误,打印错误信息并释放上下文,然后退出
        printf("Error: %s\n", c->errstr);
        redisFree(c);
        return 1;
    } else {
        // 连接成功时打印消息
        printf("Successfully connected to Redis server\n");
    }

    // 切换到数据库6
    redisReply *reply;
    reply = redisCommand(c, "SELECT 6");
    if (reply == NULL) {
        printf("Error executing SELECT command\n");
        redisFree(c);
        return 1;
    } else if (reply->type == REDIS_REPLY_ERROR) {
        printf("Error reply: %s\n", reply->str);
        freeReplyObject(reply);
        redisFree(c);
        return 1;
    }
    freeReplyObject(reply);

    // 插入一些数据,例如插入一个键值对 "name": "John"
    reply = redisCommand(c, "SET name John");
    if (reply == NULL) {
        printf("Error executing SET command\n");
        redisFree(c);
        return 1;
    } else if (reply->type == REDIS_REPLY_ERROR) {
        printf("Error reply: %s\n", reply->str);
        freeReplyObject(reply);
        redisFree(c);
        return 1;
    }
    freeReplyObject(reply);

    // 可以继续插入更多数据
    reply = redisCommand(c, "SET age 30");
    if (reply == NULL) {
        printf("Error executing SET command\n");
        redisFree(c);
        return 1;
    } else if (reply->type == REDIS_REPLY_ERROR) {
        printf("Error reply: %s\n", reply->str);
        freeReplyObject(reply);
        redisFree(c);
        return 1;
    }
    freeReplyObject(reply);

    redisFree(c);
    return 0;
}

3.结果

相关推荐
乘云数字DATABUFF20 小时前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
犯困蛋挞yy2 天前
用Claude快速解决Redis代码报错反复无解的问题
redis
Web3探索者3 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo3 天前
Linux系统中网线与USB网络共享冲突
linux
荣--3 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森3 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜3 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
Sokach10154 天前
Linux Shell 脚本从零到能用:一个新手的一天学习总结
linux
SelectDB4 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
AlfredZhao4 天前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone