2015-04-26 00:11:10 +08:00
|
|
|
#pragma once
|
2016-04-12 20:11:15 +08:00
|
|
|
#include <map>
|
2015-04-26 00:11:10 +08:00
|
|
|
|
|
|
|
class redis_util
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
redis_util(void);
|
|
|
|
~redis_util(void);
|
|
|
|
|
|
|
|
// get the node's id of the given addr
|
2016-03-13 20:01:41 +08:00
|
|
|
static bool get_node_id(const char* addr, acl::string& node_id,
|
|
|
|
const char* passwd);
|
2015-04-26 00:11:10 +08:00
|
|
|
|
|
|
|
// get the current node's ID
|
|
|
|
static bool get_node_id(acl::redis& redis, acl::string& node_id);
|
|
|
|
|
|
|
|
// get ip from the addr which format is ip:port
|
2016-03-13 20:01:41 +08:00
|
|
|
static bool get_ip(const char* addr, acl::string& ip);
|
|
|
|
|
|
|
|
static bool addr_split(const char* addr, acl::string& ip, int& port);
|
2015-04-26 00:11:10 +08:00
|
|
|
|
|
|
|
// show the nodes's information, including master and slave
|
|
|
|
static void print_nodes(int nested,
|
|
|
|
const std::vector<acl::redis_node*>& nodes);
|
|
|
|
|
|
|
|
// free all nodes nestly
|
|
|
|
static void free_nodes(const std::vector<acl::redis_node*>& nodes);
|
2016-03-13 20:01:41 +08:00
|
|
|
|
|
|
|
// sorting the givent redis_nodes by which machine ip
|
|
|
|
static void sort(const std::map<acl::string, acl::redis_node*>& in,
|
|
|
|
std::map<acl::string, std::vector<acl::redis_node*>* >& out);
|
|
|
|
|
|
|
|
// free vector holding redis_nodes
|
|
|
|
static void clear_nodes_container(
|
|
|
|
std::map<acl::string, std::vector<acl::redis_node*>* >& nodes);
|
2016-04-12 20:11:15 +08:00
|
|
|
|
|
|
|
// get all the masters of cluster
|
|
|
|
static const std::map<acl::string, acl::redis_node*>*
|
|
|
|
get_masters(acl::redis&);
|
|
|
|
|
|
|
|
// get nodes formed bye one node maybe master or slave of the cluster
|
|
|
|
static void get_nodes(acl::redis& redis, bool prefer_master,
|
|
|
|
std::vector<acl::redis_node*>& nodes);
|
|
|
|
|
|
|
|
private:
|
|
|
|
static const std::map<acl::string, acl::redis_node*>*
|
|
|
|
get_masters2(acl::redis&);
|
2015-04-26 00:11:10 +08:00
|
|
|
};
|