Redis主从复制操作和配置详情


Posted in Redis onSeptember 23, 2022

前言

环境:CentOS7下安装Redis集群,默认已安装好5.0及以上版本,操作包括:

  • Redis-server环境变量
  • 配置配置集群的
  • Redis.confRedis主从配置和启动
  • 测试主从机的数据一致性和读写分离

一、Redis-server环境变量

启动redis服务报错:

-bash: redis-server: command not found

原因:

没有配置对应命令,类似于window的环境变量,所以命令找不到

解决办法:

将安装目录下的redis-server执行文件路径配置到系统执行命令里
ln -s /usr/local/redis/redis-4.0.9/src/redis-server /usr/bin/redis-server

其中
/usr/local/redis/redis-4.0.9/src/redis-server 为安装目录下的redis-server服务文件地址

二、配置集群的Redis.conf

我们在一台服务器上开启三个Redis服务,模拟redis集群,一主两从,结构如下 :

Redis主从复制操作和配置详情

端口信息为7001,7002,7003(若使用的服务器记得开启端口的防火墙)

1.先创建7001~7003的三个目录,将配置文件放入对应目录并进行配置

Redis主从复制操作和配置详情

 Redis.conf配置:

  • bind:绑定的 IP,默认是本地,可以指定 IP,表示只有指定的 IP 才可访问,注释掉的话则全部 IP 都可访问。(我们是本地开三个服务,绑定不用动,如果是分布式就0.0.0.0)
  • protected-mode :保护模式(无密码 + 无绑定 = 本地访问),默认开启。这个不用动
  • port :端口,改为700x
  • daemonize :表示以守护进程的方式运行,默认 no,需要改为 yes,避免关闭客户端后,redis 也跟着关闭。我们实验用的话,可以关掉
  • requirepass :密码,默认没有密码,如果需要则设置密码
[root@VM-0-4-centos ~]# redis-cli -p 6379
# 获取密码
127.0.0.1:6379> config get requirepass	
1) "requirepass"
2) ""
# 设置密码
>127.0.0.1:6379> config set requirepass	12455
OK
# 重新关闭客户端再进入时,输入一下命令,则显示无权限
127.0.0.1:6379> keys *
(error) NOAUTH Authentication required.
# 输入密码
127.0.0.1:6379> auth 12455
OK

三、配置主从服务器

有临时和永久两种模式:

  • 修改配置文件(永久生效)
  • 在redis.conf中添加一行配置:slaveof <masterip> <masterport>
  • 使用redis-cli客户端连接到redis服务,执行slaveof命令(重启后失效):

slaveof <masterip> <masterport>

四、启动三台Redis服务器

[root@localhost bin]# redis-server /myredis/redis6379.conf
[root@localhost bin]# redis-server /myredis/redis6380.conf
[root@localhost bin]# redis-server /myredis/redis6381.conf
[root@localhost bin]# ps -ef | grep redis
root       2999      1  0 11:58 ?        00:00:00 redis-server *:6379
root       3013      1  0 11:59 ?        00:00:00 redis-server *:6380
root       3019      1  0 11:59 ?        00:00:00 redis-server *:6381
root       3025   2189  0 11:59 pts/0    00:00:00 grep --color=autoredis

 使用命令登录三个redis

redis -p  <port> -a 密码   指定端口号登录redis

执行下列操作以测试:

  • 利用redis-cli连接7001,执行set num 123
  • 利用redis-cli连接7002,执行get num,再执行set num 666
  • 利用redis-cli连接7003,执行get num,再执行set num 888

我们对从机进行写操作发现报错

对主机进行写操作,从机可以获取

可以发现,只有在7001这个master节点上可以执行写操作,7002和7003这两个slave节点只能执行读操作。

到此这篇关于Redis主从复制操作和配置详情的文章就介绍到这了,更多相关Redis主从复制 内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Redis 相关文章推荐
解决redis sentinel 频繁主备切换的问题
Apr 12 Redis
Redis遍历所有key的两个命令(KEYS 和 SCAN)
Apr 12 Redis
详解Redis实现限流的三种方式
Apr 27 Redis
Redis6.0搭建集群Redis-cluster的方法
May 08 Redis
Redis基于Bitmap实现用户签到功能
Jun 20 Redis
为什么RedisCluster设计成16384个槽
Sep 25 Redis
Redis高并发防止秒杀超卖实战源码解决方案
Nov 01 Redis
Springboot/Springcloud项目集成redis进行存取的过程解析
Dec 04 Redis
在Centos 8.0中安装Redis服务器的教程详解
Mar 21 Redis
浅谈Redis 中的过期删除策略和内存淘汰机制
Apr 03 Redis
利用Redis实现点赞功能的示例代码
Jun 28 Redis
基于Redission的分布式锁实战
基于redis+lua进行限流的方法
Jul 23 #Redis
Redis过期数据是否会被立马删除
Jul 23 #Redis
如何使用注解方式实现 Redis 分布式锁
Jul 23 #Redis
redis lua限流算法实现示例
Redis Lua脚本实现ip限流示例
Jul 15 #Redis
redis protocol通信协议及使用详解
Jul 15 #Redis
You might like
NT IIS下用ODBC连接数据库
2006/10/09 PHP
php读取html并截取字符串的简单代码
2009/11/30 PHP
php模块memcache和memcached区别分析
2011/06/14 PHP
phpcms手机内容页面添加上一篇和下一篇
2015/06/05 PHP
php利用array_search与array_column实现二维数组查找
2019/07/08 PHP
非常不错的一个javascript 类
2006/11/07 Javascript
Javascript select控件操作大全(新增、修改、删除、选中、清空、判断存在等)
2008/12/19 Javascript
Javascript 阻止javascript事件冒泡,获取控件ID值
2009/06/27 Javascript
一个不错的js html页面倒计时可精确到秒
2014/10/22 Javascript
jQuery+CSS3实现树叶飘落特效
2015/02/01 Javascript
js数组去重的5种算法实现
2015/11/04 Javascript
javascript正则表达式定义(语法)总结
2016/01/08 Javascript
Bootstrap入门书籍之(一)排版
2016/02/17 Javascript
JavaScript中的继承之类继承
2016/05/01 Javascript
JS ES6中setTimeout函数的执行上下文示例
2017/04/27 Javascript
Angular4 中内置指令的基本用法
2017/07/31 Javascript
JavaScript设计模式之构造器模式(生成器模式)定义与用法实例分析
2018/07/26 Javascript
详解Vue用cmd创建项目
2019/02/12 Javascript
国内常用的js类库大全(CDN公共库)
2020/06/24 Javascript
Vue通过Blob对象实现导出Excel功能示例代码
2020/07/31 Javascript
微信小程序实现登录注册功能
2020/12/29 Javascript
Python生成不重复随机值的方法
2015/05/11 Python
在Python中使用zlib模块进行数据压缩的教程
2015/06/26 Python
python制作小说爬虫实录
2017/08/14 Python
基于Python实现剪切板实时监控方法解析
2019/09/11 Python
python使用配置文件过程详解
2019/12/28 Python
python 实现将Numpy数组保存为图像
2020/01/09 Python
Flask处理Web表单的实现方法
2021/01/31 Python
写一个方法1000的阶乘
2012/11/21 面试题
大一学生职业生涯规划
2014/03/11 职场文书
升学宴主持词
2014/04/02 职场文书
恋恋笔记本观后感
2015/06/16 职场文书
老人与海读书笔记
2015/06/26 职场文书
各类场合主持词开场白范文集锦
2019/08/16 职场文书
六种css3实现的边框过渡效果
2021/04/22 HTML / CSS
python Django框架快速入门教程(后台管理)
2021/07/21 Python