The FreeRADIUS server $Id: 15bac2a4c627c01d1aa2047687b3418955ac7f00 $
|
Common functions for interacting with Redis cluster via Hiredis. More...
#include <freeradius-devel/server/pool.h>
Go to the source code of this file.
Data Structures | |
struct | fr_redis_cluster_state_t |
Redis connection sequence state. More... | |
Typedefs | |
typedef struct fr_redis_cluster_key_slot_s | fr_redis_cluster_key_slot_t |
typedef struct fr_redis_cluster_node_s | fr_redis_cluster_node_t |
typedef struct fr_redis_cluster | fr_redis_cluster_t |
Enumerations | |
enum | fr_redis_cluster_rcode_t { FR_REDIS_CLUSTER_RCODE_IGNORED = 1 , FR_REDIS_CLUSTER_RCODE_SUCCESS = 0 , FR_REDIS_CLUSTER_RCODE_FAILED = -1 , FR_REDIS_CLUSTER_RCODE_NO_CONNECTION = -2 , FR_REDIS_CLUSTER_RCODE_BAD_INPUT = -3 } |
Return values for internal functions. More... | |
Functions | |
fr_redis_cluster_t * | fr_redis_cluster_alloc (TALLOC_CTX *ctx, CONF_SECTION *module, fr_redis_conf_t *conf, bool enable_triggers, char const *log_prefix, char const *trigger_prefix, fr_pair_list_t *trigger_args) |
Allocate and initialise a new cluster structure. | |
void * | fr_redis_cluster_conn_create (TALLOC_CTX *ctx, void *instance, fr_time_delta_t timeout) |
Create a new connection to a Redis node. | |
int | fr_redis_cluster_ipaddr (fr_ipaddr_t *out, fr_redis_cluster_node_t const *node) |
Return the ipaddr of a particular node. | |
fr_redis_cluster_node_t const * | fr_redis_cluster_master (fr_redis_cluster_t *cluster, fr_redis_cluster_key_slot_t const *key_slot) |
Return the master node that would be used for a particular key. | |
bool | fr_redis_cluster_min_version (fr_redis_cluster_t *cluster, char const *min_version) |
Check if members of the cluster are above a certain version. | |
ssize_t | fr_redis_cluster_node_addr_by_role (TALLOC_CTX *ctx, fr_socket_t *out[], fr_redis_cluster_t *cluster, bool is_master, bool is_slave) |
Return an array of IP addresses belonging to masters or slaves. | |
int | fr_redis_cluster_pool_by_node_addr (fr_pool_t **pool, fr_redis_cluster_t *cluster, fr_socket_t *node, bool create) |
Get the pool associated with a node in the cluster. | |
int | fr_redis_cluster_port (uint16_t *out, fr_redis_cluster_node_t const *node) |
Return the port of a particular node. | |
fr_redis_cluster_rcode_t | fr_redis_cluster_remap (request_t *request, fr_redis_cluster_t *cluster, fr_redis_conn_t *conn) |
Perform a runtime remap of the cluster. | |
fr_redis_cluster_node_t const * | fr_redis_cluster_slave (fr_redis_cluster_t *cluster, fr_redis_cluster_key_slot_t const *key_slot, uint8_t slave_num) |
Return the slave node that would be used for a particular key. | |
fr_redis_cluster_key_slot_t const * | fr_redis_cluster_slot_by_key (fr_redis_cluster_t *cluster, request_t *request, uint8_t const *key, size_t key_len) |
Implements the key slot selection scheme used by freeradius. | |
fr_redis_rcode_t | fr_redis_cluster_state_init (fr_redis_cluster_state_t *state, fr_redis_conn_t **conn, fr_redis_cluster_t *cluster, request_t *request, uint8_t const *key, size_t key_len, bool read_only) |
Resolve a key to a pool, and reserve a connection in that pool. | |
fr_redis_rcode_t | fr_redis_cluster_state_next (fr_redis_cluster_state_t *state, fr_redis_conn_t **conn, fr_redis_cluster_t *cluster, request_t *request, fr_redis_rcode_t status, redisReply **reply) |
Get the next connection to attempt a command against. | |
Variables | |
fr_table_num_sorted_t const | fr_redis_cluster_rcodes_table [] |
size_t | fr_redis_cluster_rcodes_table_len |
Common functions for interacting with Redis cluster via Hiredis.
Definition in file cluster.h.
struct fr_redis_cluster_state_t |
Redis connection sequence state.
Tracks how many operations we've performed attempting to execute a single command.
Used by callers of the cluster code. Allocated on the stack and passed to fr_redis_cluster_state_init and fr_redis_cluster_state_next.
Data Fields | ||
---|---|---|
bool | close_conn | Set by caller of fr_redis_cluster_state_next, to indicate that connection must be closed, as it's now in an unknown state. |
uint32_t | in_pool | How many available connections are there in the pool. |
uint8_t const * | key | Key we performed hashing on. |
size_t | key_len | Length of the key. |
fr_redis_cluster_node_t * | node | Node we're communicating with. |
uint32_t | reconnects | How many connections we've tried in this pool. |
uint32_t | redirects | How many redirects have we followed. |
uint32_t | retries | How many times we've received TRYAGAIN. |
typedef struct fr_redis_cluster_key_slot_s fr_redis_cluster_key_slot_t |
typedef struct fr_redis_cluster_node_s fr_redis_cluster_node_t |
typedef struct fr_redis_cluster fr_redis_cluster_t |
Return values for internal functions.
fr_redis_cluster_t * fr_redis_cluster_alloc | ( | TALLOC_CTX * | ctx, |
CONF_SECTION * | module, | ||
fr_redis_conf_t * | conf, | ||
bool | triggers_enabled, | ||
char const * | log_prefix, | ||
char const * | trigger_prefix, | ||
fr_pair_list_t * | trigger_args | ||
) |
Allocate and initialise a new cluster structure.
This holds all the data necessary to manage a pool of pools for a specific redis cluster.
ctx | to link the lifetime of the cluster structure to. |
module | Configuration section to search for 'server' conf pairs in. |
conf | Base redis server configuration. Cluster nodes share database number and password. |
triggers_enabled | Whether triggers should be enabled. |
log_prefix | Custom log prefix. Defaults to rlm_<module> (<instance>). |
trigger_prefix | Custom trigger prefix. Defaults to modules.<module>.pool. |
trigger_args | Argument pairs to pass to the trigger in addition to Connection-Pool-Server, and Connection-Pool-Port (which are always set by the cluster code). |
Definition at line 2261 of file cluster.c.
void * fr_redis_cluster_conn_create | ( | TALLOC_CTX * | ctx, |
void * | instance, | ||
fr_time_delta_t | timeout | ||
) |
Create a new connection to a Redis node.
[in] | ctx | to allocate connection structure in. Will be freed at the same time as the pool. |
[in] | instance | data of type fr_redis_cluster_node_t. Holds parameters for establishing new connection. |
[in] | timeout | The maximum time allowed to complete the connection. |
Definition at line 1468 of file cluster.c.
int fr_redis_cluster_ipaddr | ( | fr_ipaddr_t * | out, |
fr_redis_cluster_node_t const * | node | ||
) |
fr_redis_cluster_node_t const * fr_redis_cluster_master | ( | fr_redis_cluster_t * | cluster, |
fr_redis_cluster_key_slot_t const * | key_slot | ||
) |
Return the master node that would be used for a particular key.
[in] | cluster | To resolve key in. |
[in] | key_slot | to resolve to node. |
Definition at line 1639 of file cluster.c.
bool fr_redis_cluster_min_version | ( | fr_redis_cluster_t * | cluster, |
char const * | min_version | ||
) |
Check if members of the cluster are above a certain version.
cluster | to perform check on. |
min_version | that must be found on each node for the check to succeed. Must be in the format <major>.<minor>.<release>. |
Definition at line 2202 of file cluster.c.
ssize_t fr_redis_cluster_node_addr_by_role | ( | TALLOC_CTX * | ctx, |
fr_socket_t * | out[], | ||
fr_redis_cluster_t * | cluster, | ||
bool | is_master, | ||
bool | is_slave | ||
) |
Return an array of IP addresses belonging to masters or slaves.
[in] | ctx | to allocate array of IP addresses in. |
[out] | out | Where to write the addresses of the nodes. |
[in] | cluster | to search for nodes in. |
[in] | is_master | If true, include the addresses of all the master nodes. |
[in] | is_slave | If true, include the addresses of all the slaves nodes. |
Definition at line 2138 of file cluster.c.
int fr_redis_cluster_pool_by_node_addr | ( | fr_pool_t ** | pool, |
fr_redis_cluster_t * | cluster, | ||
fr_socket_t * | node_addr, | ||
bool | create | ||
) |
Get the pool associated with a node in the cluster.
[out] | pool | associated with the node. |
[in] | cluster | to search for node in. |
[in] | node_addr | to retrieve pool for. Specifies IP and port of node. |
[in] | create | Establish a connection to the specified node if it was previously unknown to the cluster client. |
Definition at line 2070 of file cluster.c.
int fr_redis_cluster_port | ( | uint16_t * | out, |
fr_redis_cluster_node_t const * | node | ||
) |
fr_redis_cluster_rcode_t fr_redis_cluster_remap | ( | request_t * | request, |
fr_redis_cluster_t * | cluster, | ||
fr_redis_conn_t * | conn | ||
) |
Perform a runtime remap of the cluster.
[in] | request | The current request. |
[in,out] | cluster | to remap. |
[in] | conn | to use to query the cluster. |
Definition at line 1009 of file cluster.c.
fr_redis_cluster_node_t const * fr_redis_cluster_slave | ( | fr_redis_cluster_t * | cluster, |
fr_redis_cluster_key_slot_t const * | key_slot, | ||
uint8_t | slave_num | ||
) |
Return the slave node that would be used for a particular key.
[in] | cluster | To resolve key in. |
[in] | key_slot | To resolve to node. |
[in] | slave_num | 0..n. |
Definition at line 1655 of file cluster.c.
fr_redis_cluster_key_slot_t const * fr_redis_cluster_slot_by_key | ( | fr_redis_cluster_t * | cluster, |
request_t * | request, | ||
uint8_t const * | key, | ||
size_t | key_len | ||
) |
Implements the key slot selection scheme used by freeradius.
Like the scheme in the clustering specification but with some differences if the key is NULL or zero length, then a random keyslot is chosen.
If there's only a single node in the cluster, then we avoid the CRC16 and just use key slot 0.
cluster | to determine key slot for. |
request | The current request. |
key | the key to resolve. |
key_len | the length of the key. |
Definition at line 1603 of file cluster.c.
fr_redis_rcode_t fr_redis_cluster_state_init | ( | fr_redis_cluster_state_t * | state, |
fr_redis_conn_t ** | conn, | ||
fr_redis_cluster_t * | cluster, | ||
request_t * | request, | ||
uint8_t const * | key, | ||
size_t | key_len, | ||
bool | read_only | ||
) |
Resolve a key to a pool, and reserve a connection in that pool.
This should be used with fr_redis_cluster_state_next, and fr_redis_command_status, to transparently locate the cluster node we need to perform the operation on.
Example code below shows how this function is used in conjunction with fr_redis_cluster_state_next to follow redirects, and reconnect handles.
[out] | state | to track current pool and various counters, will be initialised. |
[out] | conn | Where to write the reserved connection to. |
[in] | cluster | of pools. |
[in] | request | The current request. |
[in] | key | to resolve to a cluster node/pool. If no key is NULL or key_len is 0 a random slot will be chosen. |
[in] | key_len | Length of the key. |
[in] | read_only | If true, will use random slave pool in preference to the master, falling back to the master if no slaves are available. |
Definition at line 1741 of file cluster.c.
fr_redis_rcode_t fr_redis_cluster_state_next | ( | fr_redis_cluster_state_t * | state, |
fr_redis_conn_t ** | conn, | ||
fr_redis_cluster_t * | cluster, | ||
request_t * | request, | ||
fr_redis_rcode_t | status, | ||
redisReply ** | reply | ||
) |
Get the next connection to attempt a command against.
Will process reconnect and redirect states performing the actions necessary.
If a remap is in progress, has occurred within the last second, has recently failed, or fails, the '-MOVE' will be treated as a temporary redirect (-ASK).
This allows the server to be more responsive during remaps, as unless the worker has been redirected to a node we don't currently have a pool for, it can grab a connection for the node it was redirected to, and continue.
[in,out] | state | containing the current pool, and various counters which control retries, and limit redirects. |
[in,out] | conn | we received the '-ASK' or '-MOVE' redirect on. Will be replaced with a connection in the new pool the key points to. |
[in] | request | The current request. |
[in] | cluster | of pools. |
[in] | status | of the last command, must be REDIS_RCODE_MOVE or REDIS_RCODE_ASK. |
[in] | reply | from last command. Freed if 0 is returned, else caller must free. |
Definition at line 1863 of file cluster.c.
|
extern |