当前位置:网站首页>Design and implementation of redis (6): how redis achieves high availability
Design and implementation of redis (6): how redis achieves high availability
2022-04-23 03:30:00 【The view of extraordinary is often far away】
Ten 、Sentinel
Sentinel( sentry ) yes Redis Of High availability (Hign Availability,HA) Solutions for , By one or more Sentinel Examples of Sentinel The system can monitor any number of master servers and all subordinate slave servers . When the primary server is offline , Automatically a slave server subordinate to a master server offline upgrade For the new master server . So as to achieve Fail over , When the original primary server goes online again , Will be downgraded to slave server .
The following shows the status of the sentinel monitoring the master and slave :
10.1 Start and initialize Sentinel
start-up Sentinel There are two ways :
- redis-sentinel /path/to/your/sentinel.conf
- redis-server /path/to/your/sentinel.conf --sentinel
The two commands have the same effect , The following steps need to be performed when starting :
- Initialize server .
- Will be ordinary Redis Replace the code used by the server with Sentinel Special code .
- initialization Sentinel state .
- According to the configuration file , initialization Sentinel The list of monitoring primary servers .
- Create a network connection to the primary server .
Initialize server
Sentinel It's actually a special Redis The server , So many places and Redis The initialization of the server is somewhat similar . But it doesn't apply to databases , So less RDB or AOF File loading and other operations .
Use Sentinel Special code
Code to be used, such as loaded constants , Command table ( To determine the Sentinel What commands can be executed ) Replace with Sentinel Special code , Port is 26379, There is no... In the command table set、get Wait for the order .
initialization Sentinel state
Initialize a sentinel.c/sentinelState structure , Record Sentinel The state of , Save all the data in the server Sentinel Relevant status :
struct sentinelState{
// Current era , Election counter , For failover
uint64_ t current_ epoch;
//( a key ) Saved all by this sentinel Primary server for monitoring
// The key of the dictionary is the name of the main server , Value is a point sentine1RedisInstance Pointer to structure
dict *masters;
// Have you entered TILT Pattern
int tilt;
// The number of scripts currently executing
int running_ scripts;
// Get into TILT Pattern time
mstime_ _t tilt_ start_ time;
// Time of last execution of time processor
mstime_ t previous_ time ;
// One FIFO queue , Contains all user scripts that need to be executed
list *scripts_ queue;
}sentinel;
initialization master attribute
masters The key of the dictionary is the name of the monitored master server , The value is corresponding to the monitored server sentinelRedisInstance structure . This structure is used in many places, such as , master server 、 From the server and another sentinel.
typedef struct sentinelRedisInstance {
// Tag value , Record the type of instance , And the current state of the instance .
int flags;
// The name of the instance .
// The name of the primary server is set by the user in the configuration file
// From the server as well as Sentinel By Sentinel Automatic setting
// The format is ip:port
char *name;
// Running of instances ID
char *runid;
// Configuration Era , For failover
uint64_t config_epoch;
// Instance address
sentinelAddr *addr;
// SENTINEL down-after-milliseconds Value of option setting
// The number of milliseconds after the instance has no response will be judged as the subjective offline
mstime_t down_after_period;
// The number of support votes required to judge this instance as an objective offline
int quorum;
// When performing a failover operation , The number of slave servers that can synchronize the new master server at the same time
int paral1el_syncs;
// Maximum time limit to refresh failover state
mstime_t failover_timeout;
// ...
} sentinelRedisInstance;
Create a network connection to the primary server
Sentinel Two asynchronous network connections are created for the monitored master server :
- Command connection : Dedicated to sending commands to the primary server , Receive command reply .
- Subscription connection : Dedicated to the subscriber master __sentinel__:hello channel .( because Redis Your publish and subscribe messages will not be saved , If the client is disconnected, it will be lost , In order not to lose , You must use a dedicated channel connection )
10.2 Get master server information
Sentinel Default 10 Seconds at a time Connect to the monitored master server through the command and send INFO command , Get master server information . It mainly obtains the information of the main server itself ( If the server is running ID), Subordinates receive information from the server ( Such as ip,port,offset). Update the structure of the main server according to the returned information , If there is no new information from the server, an instance structure will be created , On the primary server slaves In the dictionary , The key is ip+ port , The value is sentinelRedisInstance structure .
10.3 Get information from the server
When Sentinel When it is found that the master server has a new slave server , In addition to creating new instances , It also creates a connection to the slave server Command connection and Subscription connection . Every time 10S The frequency of one transmission to the slave server INFO command , Get relevant information from the server , Update the instance structure accordingly .
10.4 Send messages to the master and slave servers
sentinel Default to Once every two seconds , server-oriented **sentinel:hello channel ** Send a message , command :
PUBLISH __sentinel__:hello "<s_ip>,<s_port>,<s_runid>,<s_epoch>,<m_name>,<m_ip>,<m_port>,<m_epoch>"
Parameters include sentinel In itself (s__…) And the main server (m…) Operation of ID,ip, Port number , Configure era and other parameters .
10.5 Receive channel information from master and slave servers
Sentinel After establishing a subscription connection with a master or slave server , Will send SUBSCRIBE _sentinel_:hello
Command subscription channel .
That is to say Sentinel Send information to channel via command connection , And receive the information in the channel through the subscription connection . One Sentinel towards _sentinel_:hello The information sent by the channel will also be subscribed by others _sentinel_:hello Channel Sentinel receive , According to the information recorded Sentinel function id And receive information Sentinel function id Are they the same? , To decide Whether to deal with This message . Through this transparent communication mechanism ,Sentinel You can update the server information you listen to .
to update sentinels Dictionaries
According to from **sentinel:hello channel ** Received message ,Sentinel Will update the instance structure sentinels All that the dictionary holds Sentinel Instance information . The key is Sentinel Of ip+ port , The value is a Sentinel Example . The message receiver will check the sending message Sentinel( Source sentinel) Whether the structure is sentinels The dictionary is updated if it exists , If not, create an instance .
Through this way of publishing and subscribing ,Sentinel There is no need to provide individual Sentinel Address , Monitor multiple servers on the same primary server Sentinel You'll find each other automatically .
Create links to other Sentinel Command connection for
Sentinel It will also create command connections for each other , Finally, monitor multiple servers of the same primary server Sentinel Will form a The Internet .Sentinel Between No subscription connection will be created ,Sentinel Subscription connections with master or slave servers are used to discover unknown Sentinel, And what we know about each other Sentinel It's enough to use commands to connect and communicate .
10.6 Detect the subjective offline status
Sentinel Default per second An instance connected to the create command ( master server , From the server , other sentinel) send out PING command , Determine whether you are online by replying . Replies can be divided into two types :
- +PONG,-LOADING,-MASTERRDOWN Any one of them is Valid responses
- In addition to the above three replies, they are Invalid response .
According to the down-after-milliseconds designated Subjective offline time required Whether to always return invalid replies , To determine whether the instance has been subjectively offline . If you are offline, the instance will be flags Identity properties open SRI_S_DOWN identification . Because each Sentinel The subjective offline time configuration in can be different , All possible Some Sentinel When judging subjective offline , the other one Sentinel Consider online status .
down-after-milliseconds The configuration is not only valid for the primary server , The slave server that judges the master server and other servers that monitor the master server Sentinel Are effective .
From here, we can find that there are three timed sending commands
frequency | command / effect | sender | The receiver |
---|---|---|---|
10 Seconds at a time | INFO/ Update master-slave server information | sentinel | Master slave server |
2 Seconds at a time | PUBLISH sentinel:hello/ Get something else sentinel Information | sentinel | Server's __sentinel__:hello channel , subscribe |
All of this channel sentinel You can receive | |||
1 Seconds at a time | PING/ Judge whether the other party is online | sentinel | master server , From the server , other sentinel |
10.7 Check the objective offline status
When Sentinel When judging that the main server is subjective offline , And to others Sentinel inquiry , Get a sufficient number of offline ( It can be subjective offline or objective offline ) After judgment , The server will be judged as offline .
Source Sentinel send out sentinel is-master-down-by-addr command
Sentinel Use :SENTINEL is-master-down-by-addr <ip> <port> <current. epoch> <runid>
Order to ask for other Sentinel Do you agree to offline the primary server .
The meaning of these parameters is as follows :
The goal is Sentinel receive sentinel is-master-down-by-addr command
Others receive and return three parameters Multi Bulk reply :<down_state>、<leader_runid>、<leader_epoch>
Source Sentinel receive sentinel is-master-down-by-addr A reply to an order
Statistics other Sentinel Agree that the number of primary servers offline , When the quantity exceeds the configured value (quorum Parameters ) when ,sentinel The of the primary server instance will be flags Attribute SRI_O_DOWN Properties to open the , Indicates that you have entered the objective offline status .
Different Sentinel Because of the configuration quorum Different , The results of judging whether a server is offline objectively are different .
10.8 Elections in the lead Sentinel
When the master server is judged to be offline objectively , Monitor the of this master server sentinel Will negotiate the election of leaders sentinel, And by the leading sentinel Perform a failover operation on the offline primary server .
When SENTINEL is-master-down-by-addr
When the command has confirmed that the primary server is offline ,Sentinel Will Send again The order is of an electoral nature , And bring your own running ID. If you receive a command Sentinel When the local leader has not been set , Will run this ID As one's own Multi Bulk Reply parameters , Judge how many... According to the reply parameters Sentinel Set yourself as a local leader . Because of network delay , yes , we have Sentinel Commands are better than others Sentinel Arrive first , And win ( There has to be More than half Tickets for ), Then it is responsible for failover . An election did not produce , Re election after a period of time , Until the election , At the end of each election , Configuration Era +1.
10.9 Fail over
Failover includes 3 Step :
- Select one of the servers under the offline master server and transfer it to the master server .
- Let other slave servers copy the new master server .
- When the original primary server goes online again , Make him the slave of the new master server .
Select the new master server
How to select a new master server ?Sentinel Will put all from the server into the list , One by one Filter :
- Delete slave servers that are offline or disconnected .
- Delete recent 5 Seconds didn't reply to the leader sentinel INFO Command from server .
- Delete the server disconnected from offline for more than down-after-milliseconds*10 Millisecond from the server .
- And then according to Prioritization , If it is the same, choose Maximum offset Of , If it is still the same, select run ID The smallest .
After choosing it , Send this from the server SLAVEOF no one command , And then to Once a second Send it the frequency of INFO command , Observe the returned role If the attribute becomes master, It means that you have successfully upgraded to the primary server .
Modify the replication target from the server
Send... To all other slave servers SLAVEOF command , Let them all copy the new master server .
Change the old master server to the slave server
When the original master server goes online ,Sentinel I'm going to send it SLAVEOF command , Make him the slave of the new master server .
In actual use , The client is connected sentinel To connect master Of .Sentinel Mainly used in single instance mode ( Single host / One or more slaves ) Use in Redis Management and high availability . Use... In cluster mode Redis when , Unwanted Sentinel, Instead, use the following cluster.
11、 ... and 、 colony
Clusters are Redis Provided Distributed database programme , adopt Fragmentation To share data and provide replication and failover functions . Mainly for the nodes of the cluster , Slot assignment , Command execution , The shard , to turn to , Fail over , Introduce the message .
The role of clusters :
- Disperse the access pressure of a single server , Load balancing
- Disperse the storage pressure of a single server , Achieve scalability
- Reduce the business disaster caused by single server downtime
11.1 node
A cluster consists of multiple nodes , At first, each node is independent , Each node is only in a cluster that contains itself , To build a real cluster of components, you need to go through CLUSTER MEET Connect nodes . This command is mainly used to add the target node to the current node Redis In the cluster .
Start node
Redis When the server is started, the cluster-enable The configuration determines whether the cluster mode is enabled . Cluster related data is saved in cluster.h/clusterNode structure 、cluster.h/clusterLink The structure and cluster.h/clusterState structure .
Cluster data structure
Each node of the cluster will use clusterNode To save the current state , For example, the name of the node 、IP And ports .
struct clusterNode {
// Time of node creation
mstime_t ctime; .
// Node name , from 40 It's made up of 16 hexadecimal characters
char name [REDIS_CLUSTER_NAMELEN] ;
// Node identification
// Use various identification values to record the role of the node ( Such as master node or slave node ),
// And the current state of the node ( Like online or offline ).
int flags;
// The current configuration era for the node , For failover
uint64_t configEpoch;
// Node IP Address
char ip[REDIS_IP_STR_LEN] ;
// The port number of the node
int port;
// Save the information needed to connect nodes
clusterLink *link;
...
};
Among them link The attribute structure is clusterLink, Save cluster related data , It is associated with redisClient The difference of structure is that its socket and buffer are used to connect nodes , and redisClient It is used to connect the client .
typedef struct clusterLink {
// When the connection was created
mstime_t ctime ;
// TCP socket descriptor
int fd;
// Output buffer , Save messages waiting to be sent to other nodes ( message ).
sds sndbuf;
// Input buffer , Save messages received from other nodes .
sds rcvbuf ;
// The node associated with this connection , If not, for NULL
struct clusterNode *node;
} clusterLink;
You can find , Each node in the cluster saves data from other nodes , That is, every node in the cluster knows each other . Besides , Each node also holds this one clusterstate structure , It is used to record the status of the cluster from the current perspective .
typedef struct clusterState {
// Pointer to the current node
clusterNode *myself;
// The current era of cluster configuration , For failover
uint64_t currentEpoch;
// The current state of the cluster : Online or offline
int state;
// The number of nodes in the cluster that handle at least one slot ( The next section is about )
int size;
// Cluster node list ( Include myself node )
// The key is the node name , The value is the value corresponding to the node clusterNode structure
dict *nodes;
...
} clusterState;
clusterState Medium nodes Attribute also holds the information of each node in the cluster .
CLUSTER MEET Implementation of commands
By sending to the node CLUSTER MEET command , Let the target node join the cluster , Three times handshake , The execution process is as follows :
- The client sends the command to the node A, node A Will create a node B Of clusterNode structure , Add to clusterState.nodes in .
- analysis IP Address and port number , To the node B send out MEET news .
- Empathy , node B After receipt of , Would be A establish clusterNode Structure and add to nodes.
- node B towards A send out PONG news .
- node A Send a message to B Send a PING news .
- node B After receiving A Successfully perceive B, The handshake is complete
after , node A The node will be B Information through Gossip The protocol is propagated to other nodes in the cluster , Let other nodes also be associated with nodes B A handshake .
11.2 Slot assignment
Redis Save the key value pair by slicing , The entire database of the cluster is divided into 16384(214) Slot (slot), Every key in the database belongs to a slot , Each node can handle 0~16384 Slot . When in a cluster Each slot has a node Management time , The cluster is online ; There is a slot without node management , The cluster is offline .
send out CLUSTER ADDSLOTS <slot> [slot...]
command , You can delegate a slot to a node that is responsible for .
Record the slot assignment information of the node
clusterNode Structural slots Properties and numslot Attribute records which slots the node is responsible for and how many slots it is responsible for in total .
struct clusterNode{
// Binary digit group , The length is 16384/8=2048 byte ,
// Every index 8 position , according to 0 and 1 Determine whether the slot is responsible by the node
unsigned char slot[16384/8];
// Number of tanks responsible for processing
int numslots;
...
}
slots Property is a binary array , The length is 2048 The bytes are 16384 position . If the node is responsible for managing that slot , Then the corresponding bit value in the array is 1.
Pictured above , This node is responsible for managing 0-7 this 8 Slot . The time complexity of checking whether a node manages a slot is O(1).
Propagate the slot assignment information of the node
Each node will put its own slots The array data is sent to other nodes through messages , Other nodes will update after receiving the message clusterState In structure nodes The dictionary corresponds to clusterNode structure .
therefore , Each node in the cluster knows the range of slots that other nodes are responsible for .
Record the assignment information of all slots in the cluster
clusterState The structure of the slots The array maintains the assignment information of all slots in the cluster
typedef struct slusterState{
clusterNode *slots[16384];
...
}
If slot[i] Pointing empty , Explain the slot Not managed by the node ; If you point to a specific clusterNode The pointer to , Description: managed by this node .
clusterState.slots Array records Assignment information of all slots in the cluster , It is used to quickly find whether a slot is assigned or to which node , From the angle of the slot ;
clusterNode.slots The array records the current node Responsible for slot information , Used to find which slots are managed by the current node , From the point of view of nodes .
Either of them is missing , All lead to traversal operations when implementing corresponding functions .
CLUSTER ADDSLOTS Implementation of commands
cluster addslots <slot>
Used to assign a slot to the node , After receiving the command , First, it will traverse whether all the incoming slots are unassigned , If If one is assigned, he will report an error . If none is assigned , Delegate these slots to the current node , to update clusterState.slots The array points to the of the current node clusterNode; And then clusterNode.slots The corresponding index in the array The binary bit is set to 1. Last , Send a message Tell other nodes in the cluster , Take care of these slots yourself .
11.3 Execute commands in the cluster
When the node sends the command to the database, it is related to the key of the client , The node receiving the command calculates which slot it belongs to , Check whether this slot is assigned to itself ( according to CRC-16(key)&16383 Result To determine the slot number i, According to clusterState.slots[i] Whether to point to the current node clusterNode Judge whether you are responsible for ). If not assigned to yourself , take clusterState.slots[i] Point to the node IP And port through MOVED error (move :) Returns to the client , Instruct the client to point to the correct node and send the command again .
Cluster mode clients do not print move error , But according to move Wrong automatic steering , Print steering information . The client in stand-alone mode will print directly move error .
The implementation of the node database
Storage and management of data by nodes Redis The realization of is the same , Only nodes can only use 0 Signal library . Besides , Nodes in the clusterState In the maintenance of a slots_to_keys Jump table associated slot number and key . The score is the slot number , Nodes are keys . When a node adds a new key to the database , The node will be in slots_to_keys In the middle of relation , Otherwise, delete the association .
11.4 The shard
Redis The cluster's reshard operation can assign any number of nodes already assigned to it ( Source node ) Slot is assigned to another node instead ( The target node ), The key-value pair to which the slot belongs is also moved from the source node to the target node .
The cluster does not go offline when re splitting , Both the source and target nodes can continue to process command requests .
Re partition through cluster management software redis-trib perform , Steps are as follows :
- redis-trib Send... To the target node
CLUSTER SETSLOT <slot> IMPORTING <source_id>
command , Make the target node ready to import key value pairs from the source node . - redis-trib Send... To the source node
CLUSTER SETSLOT <slot> MIGRATING <target_id>
command , Make the source node ready to transfer key value pairs . - redis-trib Send... To the source node
CLUSTER GETKEYSINSLOT <slot> <count>
command , get count One belongs to the slot slot The key name of the key value pair ( key name ), This is actually a Batch migration It means . - For steps 3 Each key name obtained ,redis-trib Send a... To the source node
MIGRATE <target_ip> <target_ port> <key_name> 0 <timeout>
command , The key that will be selected Atomic From the source node to the target node . - Repeat steps 3 And steps 4, Until the source node saves all belonging to the slot slot All key value pairs are migrated to the target node .
- redis-trib Send... To any node in the cluster
CLUSTER SETSLOT <slot> NODE <target_ id>
command , Put the groove slot Assign to target node , adopt Messages are sent to the entire cluster , Let all nodes perceive .
11.5ASK error
During re segmentation , When the client sends a command related to the database key to the source node , Some keys in the migrated slot may be in the source node and some keys in the target node , therefore , The source node will check whether it has , Go back when you have ; No return ASK error , Instruct the client to send a command to the target node that is importing the slot . This command and MOVED similar , Do not print errors directly .
CLUSTER SETSLOT IMPORTING The implementation of the
clusterState In the maintenance of a clusterState.importing_slots_from Array , Record the slots that the current node is importing from other nodes
typedef struct clusterState{
clusterNode *importing_slots_from[16384];
...
}
If an index of the array points to a cluserNode node , Then, it means that the node is being used as the target node in the re fragmentation , And the source node is the node to which the index points .
CLUSTER SETSLOT MIGRATING The implementation of the
clusterState In the maintenance of a migrating_slot_to Array , Logs the slot where the current node is migrating to another node
typedef struct clusterState{
clusterNode *migrating_slots_to[16384];
}
If an index of the array points to a cluserNode node , Then, it means that the current node is being used as the source node in the re partition , And the target node is the node to which the index points .
ASKING command
The client received ASK After error , according to IP And port , Turn to the target node , Then send to the target node first ASKING command , Then resend the command to be executed .
The only function of this command is to open the client that sends the command REDIS_ASKING identification . With this logo , Nodes will Execute the command for the key being imported . This sign is Disposable Of , If you're right about what just happened key Carry out relevant operations , The node will return MOVED error ( Because the re segmentation is not over , It is not the node responsible for the slot ).
ASK Mistakes and MOVED False distinction
Both of these errors will lead the client to :
- MOVED The error represents the responsibility of the slot Has moved from one node to another .
- ASK The error is only used during the re migration of two nodes Temporary measures .
11.6 Replication and failover
Redis The nodes in the cluster are divided into master nodes and slave nodes , The master node is used for the processing slot , The slave node is copied to a master node , And when the replicated node goes offline , Replace the offline master node to continue processing command requests .
Set up slave nodes
Send commands to nodes CLUSTER REPLICATE <node_id>
You can make the node receiving the command become the slave node of the specified node and copy to the master node . The main process is :
- The node receiving the command is at clusterState.node In the dictionary node_id Of the corresponding node clusterNode, And then clusterState.myself.slaveof Point to this node .
- modify clusterState.myself.flags attribute , close REDIS_NODE_MASTER identification , open REDIS_NODE_SLAVE identification , Identify the node as a slave node .
- Call copy code , Copy to the master node .
When a node becomes a node, replication starts , This information will be sent to other nodes in the cluster through messages .
Fault detection
Every node in the cluster will send... To other nodes on a regular basis PING news , If you don't return within the specified time PONG news , It'll be tagged Suspected offline . Each node in the cluster will send messages to each other to exchange the status of each node , When a master node A The master node is informed by the message B Think of the master node C Enter the suspected offline status ,A It will be on its own clusterState.nodes in C Corresponding clusterNode Structural fail_reports List add B Of Offline report .
Each element in the linked list consists of clusterNodeFailReport form , In fact, this linked list is the list of offline nodes :
struct clusterNodeFailReport{
// Report that the target node is offline
struct clusterNode *node;
// For the last time from node When the node receives the offline report
// The program uses this timestamp to check whether the offline report is expired
// ( Offline reports that are too long from the current time will be deleted )
mstime_t time;
} typedef clusterNodeFailReport;
For example, the master node 7001 Received master 7002 And master nodes 7003 Think of the master node 7000 After the offline notice , The master node will be modified 7001 Of clusterState.Nodes In the dictionary 7000 Node corresponding clusterNode Structural fail_reports Linked list
In a cluster , More than half The master node of the processing slot reports a master node as suspected offline , This main node will be Marked offline . And broadcast a message about the master node to the cluster FAIL The news of , All nodes that receive messages will mark them as offline .
Fail over
When a slave finds the master node offline , Start failover . Specific steps :
- All slave nodes of the offline master node , One of the slave nodes will be selected .
- The selected slave node executes SLAVEOF no one command , Becomes the new master node .
- The new master node will be revoked and assigned to its own slot assignment to the offline master node .
- The new master node broadcasts a message to the cluster PONG news , Let other nodes know the new master node immediately .
- The new master node begins to receive command requests related to the slot it is responsible for processing , Failover complete .
To elect a new master
The specific process of cluster electing a new master node :
- Determine which election is through the configuration era of the cluster , It's a Auto increment counter , The initial value is 0.
- When a node in the cluster starts a failover operation , The value of the cluster configuration era will be increased by one .
- Each master node in the cluster responsible for processing slots has A chance to vote , The first slave node that requests a vote from the master node will get the vote of the master node .
- When the slave node finds that the master node it is replicating has gone offline , The slave node sends data to the cluster radio broadcast One CLUSTERMSG_TYPE_FAILOVER_AUTH_REQUEST news , All master nodes that receive this message and have the right to vote are required to vote to this slave node .
- If a primary node has voting rights ( It's in charge of the tank ), And this master node has not yet voted for other slave nodes , Then the main node will return a... To the slave node requesting the vote CLUSTERMSG_TYPE_FAILOVER_AUTH_ACK news , Indicates that the master node supports the slave node to become a new master node .
- Every slave node participating in the election will receive CLUSTERMSG_TYPE_FAILOVER_AUTH_ACK news , And according to their own Number of messages received To count how many primary nodes you have received .
- If there is N Primary nodes with voting rights , So when a collection from a node is greater than or equal to N/2+1 When supporting the ticket , This slave node will be selected as the new master node .
- The configuration era determines that each master node with voting rights can only vote once , So if there is N Primary nodes vote , Then have greater than or equal to N/2+1 There will only be one slave node for each support ticket , This ensures that there will only be one new master .
- If you don't get enough tickets from the node in a configuration era , Then the cluster enters a new era of configuration , and Hold the election again , Until a new master node is selected .
cluster Failover and election in sentinel What's in the is raft Algorithm , So the general process is the same .
11.7 news
Nodes in the cluster mainly transmit information by sending messages , There are mainly 5 Kind of :
- MEET news : The sender received... From the client MEET When the news , The sender sends to the receiver MEET news , Request to join Cluster sender .
- PING news : Each node in the cluster is from a known node every second Randomly choose 5 individual node , Then on I haven't sent it for the longest time PING The node that sends the message . besides , Will receive the last time PONG In the node of the message , If time exceed Configured cluster-node-timeout Option Half when , It will also send PING news .
- PONG news : The reply MEET or PING news . You can also use PONG, Tell other nodes , Refresh the relevant information of this node .
- FAIL news : When a master node judges another master node Has entered FAIL state when , The current master node will report to the cluster radio broadcast A message about offline nodes FAIL news .
- PUBLISH news : When the node receives PUBLISH On command , Execute this command , And report to the cluster radio broadcast One PUBLISH news , All received this PUBLISH The nodes of the message will all execute the same PUBLISH command .
A message consists of a message header and a message body .
About redis Of sentinel and cluster The use and precautions of can refer to :https://blog.csdn.net/angjunqiang/article/details/81190562
Horizontal expansion practice :https://www.cnblogs.com/shihuc/p/8186370.html
11、 ... and 、 Publish and subscribe
redis The publish and subscribe functions of are provided by publish、subscribe、psubscribe and unsubscribe Wait for the order to make up .psubscribe For subscription mode , One mode can correspond to multiple channels . Suppose a client issues a command , The effect is as shown in the picture .
redis Save the subscription relationship of all channels in the server state pubsub_channels in , Structure is a dictionary , The key is the channel name , The value is the linked list of the subscription channel client
struct redisSServer{
//.....
// Save subscription relationships for all channels
dict *pubsub_channels;
....
};
redis Save the subscription relationship of all modes in pubsub_patterns, Structure is a linked list
struct redisSServer{
//.....
// Save subscription relationships for all channels
list *pubsub_patterns;
....
};
notes : The content is transferred from the learning notes on YuQue , The main reference is from 《Redis Design and implementation 》 Some reference sources are no longer traceable , Infringement private deletion .
版权声明
本文为[The view of extraordinary is often far away]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/04/202204220616492634.html
边栏推荐
- 打卡:4.23 C语言篇 -(1)初识C语言 - (12)结构体
- MySql关键字GROUP_CONCAT,组合连接查询
- JS calculates the display date according to the time
- Cefsharp stores cookies and reads cookies
- There is no index in the database table. When inserting data, SQL statements are used to prevent repeated addition (Reprint)
- 全新的ORM框架——BeetlSQL介绍
- 数据库表中不建索引,在插入数据时,通过sql语句防止重复添加(转载)
- Talent Plan 学习营初体验:交流+坚持 开源协作课程学习的不二路径
- Unity basics 2
- Why is bi so important to enterprises?
猜你喜欢
2022 group programming ladder simulation l2-1 blind box packaging line (25 points)
Super easy to use asynchronous export function of Excel
关于idea调试模式下启动特别慢的优化
Unity basics 2
Detailed description of MySQL index [B + tree index, hash index, full-text index, overlay index]
7-1 introduction to finance
Supersocket is Use in net5 - startup
JS inheritance
QT dynamic translation of Chinese and English languages
Basic use of Charles
随机推荐
The query type of MySQL is very inefficient.
打卡:4.22 C语言篇 -(1)初识C语言 - (11)指针
C interface
Basic use of Charles
月薪10k-20k都无法回答的事务问题,你会吗?
File upload vulnerability summary and upload labs shooting range documentary
Advanced sorting - fast sorting
MySQL grouping query rules
Codeforces round 784 (Div. 4) (AK CF (XD) for the first time)
Supersocket is Used in net5 - command
Problem a: face recognition
. net 5 Web custom middleware implementation returns the default picture
Cefsharp stores cookies and reads cookies
Seminar playback video: how to improve Jenkins' ability to become a real Devops platform
Unity Basics
. net webapi access authorization mechanism and process design (header token + redis)
Flink customizes the application of sink side sinkfunction
Database SQL -- simulate inserting a large amount of data, importing / exporting database scripts, timestamp conversion and database basics
2021-08-31
Three types of cyclic structure