redis cluster construction
(Learning video sharing: redis video tutorial)
Before introducing the formal content , first let’s introduce the steps to build the stand-alone version of redis.
- Download the redis compressed package, and then decompress the compressed file;
- Enter the decompressed redis file directory (you can see the Makefile file at this time), and compile the redis source file;
- Install the compiled redis source files into the /usr/local/redis directory. If there is no redis directory in the /local directory, a new redis directory will be automatically created;
- Enter /usr/local/ redis/bin directory, start redis directly in ./redis-server (redis is started at the front end at this time);
- Change the redis startup mode to backend startup. The specific method is: put the redis under the decompressed redis file. Copy the .conf file to the /usr/local/redis/bin directory, and then modify the redis.conf file -> daemonize: no to daemonize: yse;
- Pass ./redis in the /bin directory -server redis.conf starts redis (background startup at this time).
In summary, the installation and startup of the redis stand-alone version is completed.
For detailed steps with pictures, please refer to -> Getting started with redis
Please forgive me for being verbose, ok, then let’s return to this topic—redis cluster construction!
1. Introduction to Redis Cluster
- redis is an open source key value storage system that has been favored by the Internet favor of the company. Before the redis3.0 version, it only supported singleton mode, and only supported clusters in version 3.0 and later. I am using the redis3.0.0 version here;
- redis cluster adopts P2P mode, which is completely decentralized and does not There is a central node or agent node;
- The redis cluster does not have a unified entrance. When the client connects to the cluster, it can connect to any node in the cluster. The nodes within the cluster communicate with each other. (PING-PONG mechanism), each node is a redis instance;
- In order to achieve high availability of the cluster, that is, to determine whether the node is healthy (can it be used normally), redis-cluster has such a voting fault tolerance Mechanism: If more than half of the nodes in the cluster vote that a node is down, then this node will fail. This is how to determine whether a node is down;
- So how to determine whether the cluster is down? -> If any node in the cluster is down, and the node has no slave node (backup node), then this The cluster is down. This is a way to determine whether the cluster is down;
- So why does the cluster hang up when any node hangs up (there is no slave node)? -> Because the cluster has 16384 built-in slots (hash slots), and all physical nodes are mapped to these 16384[0-16383] slots, or these slots are equally distributed to each node. When it is necessary to store a piece of data (key-value) in the Redis cluster, redis will first perform the crc16 algorithm on the key and then obtain a result. Then calculate the remainder of this result to 16384. This remainder will correspond to one of the slots [0-16383], and then determine which node the key-value is stored in. Therefore, once a node hangs up, the slot corresponding to the node cannot be used, which will cause the cluster to not work properly.
- To sum up, each Redis cluster can theoretically have up to 16384 nodes.
2. Environment required for cluster construction
2.1 Redis cluster requires at least 3 nodes, because the voting fault tolerance mechanism requires more than half of the nodes to think that a certain node has failed. It is down, so 2 nodes cannot form a cluster.
2.2 To ensure the high availability of the cluster, each node needs to have a slave node, that is, a backup node, so the Redis cluster requires at least 6 servers. Because I don’t have that many servers, and I can’t start that many virtual machines, so what I build here is a pseudo-distributed cluster, that is, one server runs 6 redis instances virtually, and the port number is modified to (7001-7006). Of course, the actual production environment The Redis cluster setup is the same as here.
2.3 Install ruby
3. The specific steps to build the cluster are as follows (note to turn off the firewall)
3.1 Create a new redis-cluster directory in the usr/local directory to store cluster nodes
3.2 Copy all the files in the bin directory under the redis directory to the /usr/local/redis-cluster/redis01 directory. Don’t worry there is no redis01 directory here, it will be created automatically. The operation command is as follows (note the current path):
cp -r redis/bin/ redis-cluster/redis01
3.3 Delete the snapshot file dump.rdb in the redis01 directory, and modify the redis.cnf file in the directory. Specifically, modify two places: one is to change the port number to 7001, and the other is to open In cluster creation mode, just open comments. As shown in the figure below:
Delete the dump.rdb file
Modify the port number to 7001, the default is 6379
Turn on the comment of cluster-enabled yes
3.4 Copy 5 copies of the redis-cluster/redis01 file to the redis-cluster directory (redis02-redis06), create 6 redis instances, and simulate 6 nodes of the Redis cluster. Then change the port numbers in redis.conf under the remaining five files to 7002-7006 respectively. As shown in the figure below:
Create the redis02-06 directory
Modify the port number of the redis.conf file to 7002-7006
3.5 Then start Since starting all redis nodes one by one is too troublesome, here is a script file to start redis nodes in batches. The command is start-all.sh. The content of the file is as follows:
cd redis01 ./redis-server redis.conf cd .. cd redis02 ./redis-server redis.conf cd .. cd redis03 ./redis-server redis.conf cd .. cd redis04 ./redis-server redis.conf cd .. cd redis05 ./redis-server redis.conf cd .. cd redis06 ./redis-server redis.conf cd ..
3.6 Create the startup script file After that, you need to modify the permissions of the script so that it can be executed. The instructions are as follows:
chmod +x start-all.sh
3.8 ok. So far, the six redis nodes have been started successfully. Next, the cluster will be officially started. The above are all preparatory conditions. Don’t think it’s troublesome because the pictures look lengthy. In fact, the above steps are just one sentence: create 6 redis instances (6 nodes) and start them. To build a cluster, you need to use a tool (script file), which is in the source code of the redis decompression file. Because this tool is a ruby script file, the running of this tool requires a ruby running environment, which is equivalent to the running of the java language on the jvm. So you need to install ruby. The instructions are as follows:
yum install rubyThen you need to install the ruby-related packages to the server. I am using redis-3.0.0.gem here. What you need to pay attention to is: the version of redis and ruby It is best to keep the version of the package consistent.
The installation command is as follows:
gem install redis-3.0.0.gem
3.10 Copy the ruby tool (redis-trib.rb) to the redis-cluster directory. The instructions are as follows:
cp redis-trib.rb /usr/local/redis-clusterThen use the script file To build a cluster, the instructions are as follows:
./redis-trib.rb create --replicas 1 47.106.219.251:7001 47.106.219.251:7002 47.106.219.251:7003 47.106.219.251:7004 47.106.219.251:7005 47.106.219.251:7006Note: Here you should enter the corresponding IP address based on your own server IP!
At this point, the Redi cluster is successfully established! Please pay attention to the last paragraph of text, which shows the slots (hash slots) assigned to each node. There are a total of 6 nodes here, 3 of which are slave nodes, so the 3 master nodes map 0-5460, 5461-10922, 10933-16383solts.
redis01/redis-cli -p 7001 -c
注意:一定要加上-c,不然节点之间是无法自动跳转的!如下图可以看到,存储的数据(key-value)是均匀分配到不同的节点的:
四、结语
呼~~~长舒一口气…终于搭建好了Redis集群。
整个过程其实挺简单,本篇主要正对入门级别的小伙伴,插入了很多图片,所以显得冗长,希望大家多多理解,如果不当之处,还望及时指正~
最后,加上两条redis集群基本命令:
1.查看当前集群信息
cluster info
2.查看集群里有多少个节点
cluster nodes
相关推荐:redis数据库教程
The above is the detailed content of Tutorial for beginners on redis cluster building. For more information, please follow other related articles on the PHP Chinese website!

Redis's data model and structure include five main types: 1. String: used to store text or binary data, and supports atomic operations. 2. List: Ordered elements collection, suitable for queues and stacks. 3. Set: Unordered unique elements set, supporting set operation. 4. Ordered Set (SortedSet): A unique set of elements with scores, suitable for rankings. 5. Hash table (Hash): a collection of key-value pairs, suitable for storing objects.

Redis's database methods include in-memory databases and key-value storage. 1) Redis stores data in memory, and reads and writes fast. 2) It uses key-value pairs to store data, supports complex data structures such as lists, collections, hash tables and ordered collections, suitable for caches and NoSQL databases.

Redis is a powerful database solution because it provides fast performance, rich data structures, high availability and scalability, persistence capabilities, and a wide range of ecosystem support. 1) Extremely fast performance: Redis's data is stored in memory and has extremely fast read and write speeds, suitable for high concurrency and low latency applications. 2) Rich data structure: supports multiple data types, such as lists, collections, etc., which are suitable for a variety of scenarios. 3) High availability and scalability: supports master-slave replication and cluster mode to achieve high availability and horizontal scalability. 4) Persistence and data security: Data persistence is achieved through RDB and AOF to ensure data integrity and reliability. 5) Wide ecosystem and community support: with a huge ecosystem and active community,

Key features of Redis include speed, flexibility and rich data structure support. 1) Speed: Redis is an in-memory database, and read and write operations are almost instantaneous, suitable for cache and session management. 2) Flexibility: Supports multiple data structures, such as strings, lists, collections, etc., which are suitable for complex data processing. 3) Data structure support: provides strings, lists, collections, hash tables, etc., which are suitable for different business needs.

The core function of Redis is a high-performance in-memory data storage and processing system. 1) High-speed data access: Redis stores data in memory and provides microsecond-level read and write speed. 2) Rich data structure: supports strings, lists, collections, etc., and adapts to a variety of application scenarios. 3) Persistence: Persist data to disk through RDB and AOF. 4) Publish subscription: Can be used in message queues or real-time communication systems.

Redis supports a variety of data structures, including: 1. String, suitable for storing single-value data; 2. List, suitable for queues and stacks; 3. Set, used for storing non-duplicate data; 4. Ordered Set, suitable for ranking lists and priority queues; 5. Hash table, suitable for storing object or structured data.

Redis counter is a mechanism that uses Redis key-value pair storage to implement counting operations, including the following steps: creating counter keys, increasing counts, decreasing counts, resetting counts, and obtaining counts. The advantages of Redis counters include fast speed, high concurrency, durability and simplicity and ease of use. It can be used in scenarios such as user access counting, real-time metric tracking, game scores and rankings, and order processing counting.

Use the Redis command line tool (redis-cli) to manage and operate Redis through the following steps: Connect to the server, specify the address and port. Send commands to the server using the command name and parameters. Use the HELP command to view help information for a specific command. Use the QUIT command to exit the command line tool.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

SublimeText3 Linux new version
SublimeText3 Linux latest version

Dreamweaver CS6
Visual web development tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.