单机模拟集群(三主两从)

引言

操作系统环境:Ubuntu 20.04
Redis版本:6.2.8

准备工作

如果已经安装过了,找到自己的安装路径。如果没有安装过,去官网下载 当前最新版本是7.0,我这里用的是6.0,下载 redis-6.2.8.tar.gz,拷贝到自己的虚拟机或者云服务器。

tar -zxvf redis-6.2.8.tar.gz 解压
cd redis-6.2.8
make && make install (注意是root权限)

目标

在一台机器通过监听不同的port模拟集群(三台主服务器,每台主服务器有两个从服务器,总共9台服务器)
在这里插入图片描述

1、在redis的目录中创建redis_cluster文件夹

cd redis-6.2.8
mkdir redis_cluster

2、 在redis_cluster文件夹中分别创建端口号的文件夹(6390-6398)

mkdir 6390 6391 6392 6393 6394 6395 6396 6397 6398

3、以6390为例,在6390目录下创建文件redis.conf,并添加如下配置

注意:需要在步骤二创建的每个文件夹下创建配置文件,并做相应修改。

touch redis.conf

#端口号
port 6390
#默认ip为127.0.0.1,需要改为其他节点机器可以访问的ip,否则创建集群时无法访问对应的端口,无法创建集群
bind 192.168.60.69
#redis后台运行
daemonize yes
#pidfile文件对应6390,6391,6392…
pidfile /var/run/redis_6390.pid
#开启集群
cluster-enabled yes
#集群的配置,配置文件首次启动自动生成6390,6391,6392…
cluster-config-file nodes_6390.conf
#请求超时,默认15秒,可自行设置
cluster-node-timeout 10100
#aof日志开启,有需要就开启,它会每次写操作都记录一条日志
appendonly yes

4、分别向分别向6381-6388目录copy一份配置文件

cp -r redis.conf ../6391
cp -r redis.conf ../6392
cp -r redis.conf ../6393
cp -r redis.conf ../6394
cp -r redis.conf ../6395
cp -r redis.conf ../6396 
cp -r redis.conf ../6397
cp -r redis.conf ../6398

需要修改的配置:

port 639x  (根据端口号修改)
bind 127.0.0.1  我这里是本机模拟,写的本地地址,根据实际ip地址填写
pidfile /var/run/redis_639x.pid(根据端口号修改)
cluster-config-file nodes_639x.conf(根据端口号修改)

5. 启动Redis各个节点服务(一定要在src目录下启动,在其他地方无法启动)

./redis-server …/redis_cluster/6390/redis.conf
./redis-server …/redis_cluster/6391/redis.conf
./redis-server …/redis_cluster/6392/redis.conf
./redis-server …/redis_cluster/6393/redis.conf
./redis-server …/redis_cluster/6394/redis.conf
./redis-server …/redis_cluster/6395/redis.conf
./redis-server …/redis_cluster/6396/redis.conf
./redis-server …/redis_cluster/6397/redis.conf
./redis-server …/redis_cluster/6398/redis.conf

也可以写个脚本启动,就不用一个一个启动了:
vi cluster.sh

#!bin/bash
redis-server 6390/redis.conf
redis-server 6391/redis.conf
redis-server 6392/redis.conf
redis-server 6393/redis.conf
redis-server 6394/redis.conf
redis-server 6395/redis.conf
redis-server 6396/redis.conf
redis-server 6397/redis.conf
redis-server 6398/redis.conf

给脚本赋予执行权限 : chmod +x cluster.sh
运行脚本:./cluster.sh

6. 创建redis集群

因为redis最终是以数据库的形式的存在,原理和mysql一样,集群创建成功只能说明安装redis成功了,但是最终>
!!!注意还需要在redis的src目录下运行
当第一次运行的时候,才需要创建数据库,以后的每一次运行都不再需要了,直接启动集群即可

–cluster-replicas 2表示每个主节点有2个从节点

redis-cli --cluster create 127.0.0.1:6390 127.0.0.1:6391 127.0.0.1:6392 127.0.0.1:6393 127.0.0.1:6394 127.0.0.1:6395 127.0.0.1:6396 127.0.0.1:6397 127.0.0.1:6398 --cluster-replicas 2

注意:这里需要自己手动输入yes,如果超时了还没有输入,则会自动退出,需要再次创建!

看到以下信息说明创建redis集群搭建成功,且16384个槽位分配成功,:
M: eabfa31d4e7cefa01a64ec5e67ddba219ad74035 127.0.0.1:6390
   slots:[0-5460] (5461 slots) master
M: 2ac5623a741d707d4e2319795386d7e13b2ef575 127.0.0.1:6391
   slots:[5461-10922] (5462 slots) master
M: 6e4cfc6b5918ed9b59e8e7c8765f1e37a86d3d1b 127.0.0.1:6392
   slots:[10923-16383] (5461 slots) master
S: 41fdf2a9bec000cb282bd9bc75a1aa7f33417889 127.0.0.1:6393
   replicates 6e4cfc6b5918ed9b59e8e7c8765f1e37a86d3d1b
S: 15403c0a88c4ccf9ad2b67364588819621774085 127.0.0.1:6394
   replicates eabfa31d4e7cefa01a64ec5e67ddba219ad74035
S: 38ccc4d1ff1d7a3a31ed5ee805e5c479a6114588 127.0.0.1:6395
   replicates 6e4cfc6b5918ed9b59e8e7c8765f1e37a86d3d1b
S: 6f9550397b996b1d53eaeb98d344cef3945ac482 127.0.0.1:6396
   replicates 2ac5623a741d707d4e2319795386d7e13b2ef575
S: 78be26f6bdaa88e96e61ba145ba4236f59e9c5bc 127.0.0.1:6397
   replicates 2ac5623a741d707d4e2319795386d7e13b2ef575
S: b6429d56397229322f3144b59b3c7e79904fa349 127.0.0.1:6398
   replicates eabfa31d4e7cefa01a64ec5e67ddba219ad74035
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join
......
>>> Performing Cluster Check (using node 127.0.0.1:6390)
M: eabfa31d4e7cefa01a64ec5e67ddba219ad74035 127.0.0.1:6390
   slots:[0-5460] (5461 slots) master
   2 additional replica(s)
S: 78be26f6bdaa88e96e61ba145ba4236f59e9c5bc 127.0.0.1:6397
   slots: (0 slots) slave
   replicates 2ac5623a741d707d4e2319795386d7e13b2ef575
M: 6e4cfc6b5918ed9b59e8e7c8765f1e37a86d3d1b 127.0.0.1:6392
   slots:[10923-16383] (5461 slots) master
   2 additional replica(s)
S: 6f9550397b996b1d53eaeb98d344cef3945ac482 127.0.0.1:6396
   slots: (0 slots) slave
   replicates 2ac5623a741d707d4e2319795386d7e13b2ef575
S: 15403c0a88c4ccf9ad2b67364588819621774085 127.0.0.1:6394
   slots: (0 slots) slave
   replicates eabfa31d4e7cefa01a64ec5e67ddba219ad74035
S: 38ccc4d1ff1d7a3a31ed5ee805e5c479a6114588 127.0.0.1:6395
   slots: (0 slots) slave
   replicates 6e4cfc6b5918ed9b59e8e7c8765f1e37a86d3d1b
M: 2ac5623a741d707d4e2319795386d7e13b2ef575 127.0.0.1:6391
   slots:[5461-10922] (5462 slots) master
   2 additional replica(s)
S: b6429d56397229322f3144b59b3c7e79904fa349 127.0.0.1:6398
   slots: (0 slots) slave
   replicates eabfa31d4e7cefa01a64ec5e67ddba219ad74035
S: 41fdf2a9bec000cb282bd9bc75a1aa7f33417889 127.0.0.1:6393
   slots: (0 slots) slave
   replicates 6e4cfc6b5918ed9b59e8e7c8765f1e37a86d3d1b
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.

可以看到:

  1. 127.0.0.1:6390 127.0.0.1:6391 127.0.0.1:6392 是三个主服务器
  2. 6394 和 6398 是6390的从服务器
  3. 6396 和 6397 是6391的从服务器
  4. 6393 和 6395 是6392的从服务器

7. 检查redis集群是否启动成功

ps -ef | grep redis

看到如下信息就说明集群启动成功了。

root 2418510 1 0 11:32 ? 00:00:00 ./redis-server 127.0.0.1:6390 [cluster]
root 2418609 1 0 11:32 ? 00:00:00 ./redis-server 127.0.0.1:6391 [cluster]
root 2418712 1 0 11:32 ? 00:00:00 ./redis-server 127.0.0.1:6392 [cluster]
root 2418815 1 0 11:32 ? 00:00:00 ./redis-server 127.0.0.1:6393 [cluster]
root 2419062 1 0 11:32 ? 00:00:00 ./redis-server 127.0.0.1:6394 [cluster]
root 2419278 1 0 11:33 ? 00:00:00 ./redis-server 127.0.0.1:6395 [cluster]
root 2419440 1 0 11:33 ? 00:00:00 ./redis-server 127.0.0.1:6396 [cluster]
root 2419575 1 0 11:33 ? 00:00:00 ./redis-server 127.0.0.1:6397 [cluster]
root 2419749 1 0 11:33 ? 00:00:00 ./redis-server 127.0.0.1:6398 [cluster]

8. 集群状态查看及数据测试

进入redis的服务器客户端,也必须要在src目录下进行。其中,-c 表示以集群的方式启动节点,-p 是节点的端口

./redis-cli -c -p 6390

输入cluster info 查看集群状态
单机模拟集群(三主两从)_第1张图片
输入cluster nodes 查看集群各个节点主从关系
单机模拟集群(三主两从)_第2张图片
单机模拟集群(三主两从)_第3张图片

9. 退出

quit

10、注意

集群是去中心化的,从任意一个从节点,都可以访问到主节点。
集群的读写都走主节点

你可能感兴趣的:(Redis从入门到放弃,数据库,redis,服务器)