要在C++中实现一个路由服务器(Route Server)以连接到不同的Redis服务器,你可以按照以下步骤进行:
- 引入必要的头文件:
#include <iostream>
#include <string>
#include <hiredis/hiredis.h>
- 创建一个函数来连接和执行命令:
std::string executeRedisCommand(const std::string& ip, int port, const std::string& command) {
redisContext* context = redisConnect(ip.c_str(), port);
if (context == nullptr || context->err) {
if (context) {
std::cerr << "Error connecting to Redis: " << context->errstr << std::endl;
redisFree(context);
} else {
std::cerr << "Failed to allocate Redis context" << std::endl;
}
return "";
}
redisReply* reply = static_cast<redisReply*>(redisCommand(context, command.c_str()));
if (reply == nullptr) {
std::cerr << "Error executing Redis command: " << context->errstr << std::endl;
freeReplyObject(reply);
redisFree(context);
return "";
}
std::string result = reply->str;
freeReplyObject(reply);
redisFree(context);
return result;
}
- 在主函数中使用该函数来执行Redis命令:
int main() {
// 连接第一个Redis服务器并执行命令
std::string result1 = executeRedisCommand("ip1", 6379, "GET key");
// 连接第二个Redis服务器并执行命令
std::string result2 = executeRedisCommand("ip2", 6379, "SET key value");
// 输出结果
std::cout << "Result from Redis 1: " << result1 << std::endl;
std::cout << "Result from Redis 2: " << result2 << std::endl;
return 0;
}
请确保在编译时链接正确的Hiredis库。上述代码只是一个简单的示例,你可以根据实际需求进行适当的修改和扩展。
内容由零声教学AI助手提供,问题来源于学员提问




