【centos7系统】Redis-6.2.2版本集群搭建

转载说明:如果您喜欢这篇文章并打算转载它,请私信作者取得授权。感谢您喜爱本文,请文明转载,谢谢。


前redis最新版本已经是6.2.4,在集群搭建上和redis3.x、redis4.x区别很大。redis5以后,就不需要安装ruby了,并且新版本redis创建集群不再使用redis-trib.rb ,而使用redis-cli。以下为新版redis6.2.2集群搭建记录。

集群搭建规划:

|------------|--------------|-----------------|
| IP | hostname | redis实例&端口 |
| 10.0.0.101 | test101 | 7000、7001 |
| 10.0.0.102 | test102 | 7000、7001 |
| 10.0.0.103 | test103 | 7000、7001 |

环境准备:

1、3台服务器都关闭防火墙和selinux2、3台服务器修改以下参数:

复制代码
echo '* soft nofile 102400' >> /etc/security/limits.conf
echo '* hard nofile 204800' >> /etc/security/limits.conf
echo '* soft memlock unlimited' >> /etc/security/limits.conf
echo '* hard memlock unlimited' >> /etc/security/limits.conf
echo 1 > /proc/sys/net/ipv6/conf/all/disable_ipv6
echo 1 > /proc/sys/net/ipv6/conf/default/disable_ipv6

echo "### update the /etc/sysctl.conf"
echo 'vm.max_map_count=262144' >> /etc/sysctl.conf
echo 'vm.overcommit_memory = 1' >> /etc/sysctl.conf
sysctl -p

搭建和启动redis实例

在test101安装redis,步骤:

1、将redis-6.2.2.tar.gz(下载地址:https://redis.io/download)上传到服务器上,解压并编译

复制代码
yum -y install gcc
tar xzf redis-6.2.2.tar.gz -C /home/
cd /home/redis-6.2.2
make MALLOC=libc 
make PREFIX=/home/redis-6.2.2  install

2、创建相关目录,修改配置文件

复制代码
mkdir /home/rediscluster/{7000,7001} -p
mkdir /homerediscluster/7000/{conf,data,log} -p
mkdir /home/rediscluster/7001/{conf,data,log} -p
cp /home/redis-6.2.2/redis.conf /home/rediscluster/7000/conf/
cp /home/redis-6.2.2/redis.conf /home/rediscluster/7001/conf/

3、修改配置文件修改/home/rediscluster/7000/conf/redis.conf(以下集群配置为必须修改,其余配置根据实际情况修改):

复制代码
第75行:bind 10.0.0.101
第98行:port 7000
第257行:daemonize yes
第289行: pidfile "/home/rediscluster/7000/data/redis_7000.pid"
第302行:logfile "/home/rediscluster/7000/log/redis_7000.log"
第431行:dbfilename dump-7000.rdb
第454行: dir "/home/rediscluster/7000/data/"
第484行:masterauth "myredis"
第901行: requirepass "myredis"
第1385行:cluster-enabled yes
第1399行:cluster-node-timeout 5000

将7000目录的配置文件拷贝到7001实例并注意将配置文件的7000改为7001:

复制代码
cp /home/rediscluster/7000/conf/redis.conf  /home/rediscluster/7001/conf/redis.conf
sed -i 's#7000#7001#g' /home/rediscluster/7001/conf/redis.conf

改好之后,目录结构如下:

4、配置环境变量

复制代码
echo 'export  REDIS_HOME=/home/redis-6.2.2' >> /etc/profile 
echo 'export  PATH=$REDIS_HOME/bin:$PATH' >> /etc/profile
source /etc/profile

5、启动redis:

复制代码
redis-server /home/rediscluster/7000/conf/redis.conf
redis-server /home/rediscluster/7001/conf/redis.conf

6、在test102和test103重复test101的搭建步骤,注意将redis.conf里面的bind IP改为本机IP。保证三台服务器的redis节点正常启动:

创建redis集群

在三台服务器的redis实例成功启动后,在test101上执行命令创建集群(注意如果在redis.conf中设置了密码,这里就要加上-a '密码',如果没有密码,就不加-a参数):

复制代码
redis-cli --cluster create --cluster-replicas 1 10.0.0.101:7000  10.0.0.101:7001  10.0.0.102:7000  10.0.0.102:7001  10.0.0.103:7000  10.0.0.103:7001 -a myredis

创建过程截图,注意图中确认输入"yes":

验证redis集群

集群创建成功后,登录redis验证,注意加上集群参数 -c:

复制代码
# redis-cli -h 10.0.0.101 -p 7000 -a myredis -c  #登录redis集群
10.0.0.101:7000> cluster nodes  #查看集群节点
10.0.0.101:7000> cluster info   #查看集群信息

创建个key验证:

复制代码
10.0.0.101:7000> set name crystal
-> Redirected to slot [5798] located at 10.0.0.102:7000
OK
10.0.0.102:7000> get name
"crystal"
10.0.0.102:7000> 
10.0.0.102:7000> del name
(integer) 1
10.0.0.102:7000> 
10.0.0.102:7000> get name
(nil)
10.0.0.102:7000> 
10.0.0.102:7000>

执行过程截图:

验证OK,redis6.2.2 集群搭建完毕。

相关推荐
Anastasiozzzz6 分钟前
阿亮随手记:MySQL移除查询缓存、子查询优化深分页、自增主键溢出、索引失效
数据库·mysql·缓存
ppp今天又没打瓦30 分钟前
围达梦数据库批量插入更新性能实测:普通表、一级分区与二级分区的对决
数据库
@insist1231 小时前
软考-数据库系统工程师-计算机体系结构与流水线核心考点解析
数据库·软考·数据系统工程师
可观测性用观测云1 小时前
KES(KingbaseES)数据库监控最佳实践
数据库
新缸中之脑2 小时前
在Reddit上探索未满足的需求
数据库·oracle
安当加密2 小时前
用 SMS 凭据管理系统替代 HashiCorp Vault:中小企业的轻量级 Secrets 管理实践
服务器·数据库·安全·阿里云
haixingtianxinghai2 小时前
深入 MySQL 内核:从 B+ 树索引到 InnoDB MVCC 并发控制机制解析
数据库·mysql
断手当码农2 小时前
Redis 脑裂:原理、危害与解决方案
redis
jason_renyu3 小时前
数据库关联查询(JOIN)完全指南
数据库·数据库关联查询·关联查询指南·数据库关联查询学习
是码龙不是码农3 小时前
MySQL 锁的完整分类与详解
数据库·mysql·