acl/lib_acl_cpp/include/acl_cpp/redis/redis_node.hpp

269 lines
7.5 KiB
C++
Raw Normal View History

#pragma once
2017-06-02 14:47:24 +08:00
#include "../acl_cpp_define.hpp"
#include <vector>
#include <utility>
2017-06-02 14:47:24 +08:00
#include "../stdlib/string.hpp"
#include "../stdlib/noncopyable.hpp"
#if !defined(ACL_CLIENT_ONLY) && !defined(ACL_REDIS_DISABLE)
namespace acl
{
2015-04-08 23:17:16 +08:00
/**
* redis_cluster redis
2015-04-08 23:17:16 +08:00
* this class is mainly used for redis_cluster command class to
* get some information about the nodes in redis cluster
*/
class ACL_CPP_API redis_node : public noncopyable
{
public:
2015-04-08 23:17:16 +08:00
/**
* 使 set_id set_addr
* redis set_xxx
2015-04-19 22:15:30 +08:00
*/
redis_node(void);
~redis_node(void);
2015-04-19 22:15:30 +08:00
/**
* ID
2015-04-19 22:15:30 +08:00
* set the node's ID
* @param id {const char*} redis
2015-04-19 22:15:30 +08:00
* the unique ID for one redis node in the reids cluster
* @return {redis_node&}
*/
redis_node& set_id(const char* id);
/**
*
2015-04-19 22:15:30 +08:00
* set the node's listening addr
* @param addr {const char*} redis ip:port
2015-04-19 22:15:30 +08:00
* the listening addr of one redis node in the reids cluster
* @return {redis_node&}
*/
redis_node& set_addr(const char* addr);
/**
*
2015-04-19 22:15:30 +08:00
* set the current node's type
* @param type {const char*}
* @return {redis_node&}
*/
redis_node& set_type(const char* type);
/**
*
2015-04-19 22:15:30 +08:00
* set if the current node is belonging to the current connection
* @param yesno {bool}
* @return {redis_node&}
*/
redis_node& set_myself(bool yesno);
2015-04-08 23:17:16 +08:00
/**
*
2015-04-08 23:17:16 +08:00
* setting current slave node's master node
* @param master {const redis_node*}
2015-04-08 23:17:16 +08:00
* the redis master node of the current slave in cluster
2015-04-19 22:15:30 +08:00
* @return {redis_node&}
*/
redis_node& set_master(const redis_node* master);
/**
*
2015-04-19 22:15:30 +08:00
* set the current node being in handshaking status
* @param yesno {bool}
* @return {redis_node&}
2015-04-08 23:17:16 +08:00
*/
2015-04-19 22:15:30 +08:00
redis_node& set_handshaking(bool yesno);
/**
* 线
2015-04-19 22:15:30 +08:00
* set the node been connected in the cluster
* @param yesno {bool}
* @return {redis_node&}
*/
redis_node& set_connected(bool yesno);
2015-04-08 23:17:16 +08:00
/**
*
2015-04-08 23:17:16 +08:00
* setting current node's master node when the node is slave node
* @param id {const char*}
2015-04-08 23:17:16 +08:00
* the unique ID of the master node
2015-04-19 22:15:30 +08:00
* @return {redis_node&}
2015-04-08 23:17:16 +08:00
*/
2015-04-19 22:15:30 +08:00
redis_node& set_master_id(const char* id);
2015-04-08 23:17:16 +08:00
/**
*
2015-04-08 23:17:16 +08:00
* add one slave node to the current node if it's one master node
* @return {bool} false
2015-04-08 23:17:16 +08:00
* false will be returned when the slave to be added is already
* existing in the current master node
*/
bool add_slave(redis_node* slave);
2015-04-08 23:17:16 +08:00
/**
*
2015-04-08 23:17:16 +08:00
* when the current node is a master node, this function will
* remove one slave node by the unique ID
* @param id {const char*} redis
2015-04-08 23:17:16 +08:00
* the unique ID of the redis node
* @return {const redis_node*} NULL
2015-04-08 23:17:16 +08:00
* the slave node according to the ID will be returned, and if
* not exists NULL will be returned
*/
redis_node* remove_slave(const char* id);
/**
*
2015-04-08 23:17:16 +08:00
* clear all the slave nodes in the current master node
* @param free_all {bool}
2015-04-08 23:17:16 +08:00
* if freeing the all slave nodes memory meanwhile
*/
void clear_slaves(bool free_all = false);
2015-04-08 23:17:16 +08:00
/**
*
2015-04-08 23:17:16 +08:00
* add hash-slots range to the master node
* @param min {size_t}
2015-04-08 23:17:16 +08:00
* the begin hash-slot of the slots range
* @param max {size_t}
2015-04-08 23:17:16 +08:00
* the end hash-slot of the slots range
*/
void add_slot_range(size_t min, size_t max);
2015-04-08 23:17:16 +08:00
/**
*
*
2015-04-08 23:17:16 +08:00
* @return {const std::vector<std::pair<size_t, size_t> >&}
*/
const std::vector<std::pair<size_t, size_t> >& get_slots() const;
2015-04-19 22:15:30 +08:00
/**
*
2015-04-19 22:15:30 +08:00
* get the node's type
* @return {const char*}
*/
const char* get_type() const
{
return type_.c_str();
}
/**
*
2015-04-19 22:15:30 +08:00
* check if the node belongs to the current connection
* @return {bool}
*/
bool is_myself() const
{
return myself_;
}
/**
*
2015-04-19 22:15:30 +08:00
* check if the node is in handshaking status
* @return {bool}
*/
bool is_handshaking() const
{
return handshaking_;
}
/**
* 线
2015-04-19 22:15:30 +08:00
* check if the node is connected in the cluster
* @return {bool}
*/
bool is_connected() const
{
return connected_;
}
2015-04-08 23:17:16 +08:00
/**
*
2015-04-08 23:17:16 +08:00
* get the current slave's master node
* @return {const redis_node*}
*/
const redis_node* get_master() const
{
return master_;
}
2015-04-08 23:17:16 +08:00
/**
* ID
2015-04-08 23:17:16 +08:00
* when the current node is slave, getting its master's ID
* @return {const char*}
*/
const char* get_master_id() const
{
return master_id_.c_str();
}
2015-04-08 23:17:16 +08:00
/**
*
2015-04-08 23:17:16 +08:00
* getting all the slaves of the master
* @return {const std::vector<redis_node*>*}
*/
const std::vector<redis_node*>* get_slaves() const
{
2015-04-19 22:15:30 +08:00
return &slaves_;
}
2015-04-08 23:17:16 +08:00
/**
*
2015-04-08 23:17:16 +08:00
* check if the current node is a master in the redis cluster
* @return {bool}
*/
bool is_master() const
{
return master_ == this;
}
2015-04-08 23:17:16 +08:00
/**
* ID
2015-04-08 23:17:16 +08:00
* get the unique ID of the current node, set in constructor
* @return {const char*}
*/
const char* get_id() const
{
return id_.c_str();
}
2015-04-08 23:17:16 +08:00
/**
*
2015-04-08 23:17:16 +08:00
* get the listening addr of the current node, set in constructor
* @reutrn {const char*}
*/
const char* get_addr() const
{
return addr_.c_str();
}
/**
* result of CLUSTER NODES for redis.4.x.x:
* d52ea3cb4cdf7294ac1fb61c696ae6483377bcfc 127.0.0.1:16385@116385 master - 0 1428410625374 73 connected 5461-10922
* @return return 127.0.0.1:16385@116385 for redis.4.x.x
*/
const char* get_addr_info() const
{
return addr_info_.c_str();
}
private:
string id_;
string addr_;
string addr_info_;
2015-04-19 22:15:30 +08:00
string type_;
bool myself_;
bool handshaking_;
bool connected_;
const redis_node* master_;
string master_id_;
std::vector<redis_node*> slaves_;
std::vector<std::pair<size_t, size_t> > slots_;
};
} // namespace acl
#endif // !defined(ACL_CLIENT_ONLY) && !defined(ACL_REDIS_DISABLE)