一.前言
1.为何要主从架构
避免单机故障,主服务器挂掉后,还可以手动切换从服务为主服务继续工作,保持缓存数据完整。

2.主从同步的原理步骤
从服务器连接主服务器,发送SYNC命令;
主服务器接收到SYNC命名后,开始执行BGSAVE命令生成RDB文件并使用缓冲区记录此后执行的所有写命令;
主服务器BGSAVE执行完后,向所有从服务器发送快照文件,并在发送期间继续记录被执行的写命令;
从服务器收到快照文件后丢弃所有旧数据,载入收到的快照;
主服务器快照发送完毕后开始向从服务器发送缓冲区中的写命令;
从服务器完成对快照的载入,开始接收命令请求,并执行来自主服务器缓冲区的写命令;

二.配置主从

  1.环境说明

  系统基于CentOS-6.7-x86_64-minimal.iso,源码安装包redis-3.2.4版本,官方说明主从架构最好2.8版本以上

master  192.168.56.102:6379 host102
slave 192.168.56.103:6379 host103

  2.关闭防火墙、selinux

#主从两台都操作
[root@host102 ~]# /etc/init.d/iptables stop
[root@host102 ~]# setenforce 0
[root@host102 ~]# chkconfig iptables off
[root@host102 ~]# sed -i 's/^SELINUX=.*/SELINUX=disabled/' /etc/selinux/config

  3.redis配置文件

#master端配置
#复制一份默认的配置文件再修改以下个地方
[root@host102 ~]# cp /usr/local/src/redis-3.2.4/redis.conf /etc/redis/6379.conf
[root@host102 ~]# vim /etc/redis/6379.conf
bind 0.0.0.0 #监控地址
daemonize yes #dameon形式运行
pidfile /var/run/redis_6379.pid #pid文件
logfile "/var/log/redis_6379.log" #启动日志
dbfilename dump.rdb #数据文件
dir /var/lib/redis #数据目录
requirepass mima #配置连接密码

  

#slave端配置
[root@host103 ~]# vim /etc/redis/6379.conf
bind 0.0.0.0 #监控地址
daemonize yes #dameon形式运行
pidfile /var/run/redis_6379.pid #pid文件
logfile "/var/log/redis_6379.log" #启动日志
dbfilename dump.rdb #数据文件
dir /var/lib/redis #数据目录
requirepass mima #配置连接密码
slaveof 192.168.56.102 6379 #指定master
masterauth mima #slave认证master密码
slave-read-only yes #设置slave为只读模式

  4.启动服务测试读写

#启动服务
#master端
[root@host102 redis]# /usr/local/redis/bin/redis-server /etc/redis/6379.conf
#slave端
[root@host103 redis]# /usr/local/redis/bin/redis-server /etc/redis/6379.conf

  5.测试读写

#master端
[root@host102 ~]# /usr/local/redis/bin/redis-cli -a mima
127.0.0.1:6379> set name john
OK
127.0.0.1:6379> get name
"john"
127.0.0.1:6379> info replication
# Replication
role:master
connected_slaves:1
slave0:ip=192.168.56.103,port=6379,state=online,offset=239,lag=0
master_repl_offset:239
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:2
repl_backlog_histlen:238
#slave端
[root@host103 redis]# /usr/local/redis/bin/redis-cli -a mima
127.0.0.1:6379> keys *
1) "name"
127.0.0.1:6379> get name
"john"
127.0.0.1:6379> set age 28
(error) READONLY You can't write against a read only slave.
127.0.0.1:6379> info replication
# Replication
role:slave
master_host:192.168.56.102
master_port:6379
master_link_status:up
master_last_io_seconds_ago:9
master_sync_in_progress:0
slave_repl_offset:309
slave_priority:100
slave_read_only:1
connected_slaves:0
master_repl_offset:0
repl_backlog_active:0
repl_backlog_size:1048576
repl_backlog_first_byte_offset:0
repl_backlog_histlen:0

[redis] linux下主从篇(2)的更多相关文章

  1. [redis] linux下哨兵篇(3)

    一.前言1.为何部署sentinel哨兵前文redis主从架构中,当主服务故障时,需要手动将从服务切换为主服务,sentinel服务就是将这个过程自动化.主要功能有:1)不时监控主从服务正常运行2)可 ...

  2. [redis] linux下安装篇(1)

    一.redis是什么redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有 ...

  3. redis linux下的开机启动

    redis linux下的环境搭建  http://www.cnblogs.com/zsg88/p/8321644.html 安装完redis-4.0.1后设置linux开机自启动.    1.在re ...

  4. Redis linux 下安装

    Redis linux 下安装 下载Redis安装包,可以从Redis中文网站中下载 下载地址:http://www.redis.cn/download.html Redis4.0 稳定版本 使用&l ...

  5. 信步漫谈之Redis—Linux下环境搭建

    一.环境 Linux 系统:Suse11(SLES-11-SP3-DVD-x86_64-GM-DVD1)Redis 安装包:redis-4.0.11.tar.gz      下载地址:http://d ...

  6. linux下主从同步和redis的用法

    前言 mariadb其实就是mysql mysql已经被oracle收购,它即将闭源,马上要开始收费了因此还想免费试用开源的数据库mysql,就在centos7上,将mysql分支为mariadb 操 ...

  7. php使用redis扩展以及安装redis(linux下)

    一,安装redis 1,下载redis包:wget http://download.redis.io/releases/redis-2.8.9.tar.gz 2,解压redis包后,进入redis-2 ...

  8. Redis linux 下安装 及扩展配置

    1.首先在/usr/local/ 创建文件夹 reids Cd /usr/local/ mkdir redis 2.把redis安装包放在redis目录下面进行解压phpredis-2.2.4.tar ...

  9. redis linux下的环境搭建

    系统  CentOS7 Redis 官网下载   https://redis.io/download 1.下载解压 [root@TestServer-DFJR programs]# /usr/loca ...

随机推荐

  1. 混乱的 Java 日志体系

    混乱的 Java 日志体系 2016/09/10 | 分类: 基础技术 | 0 条评论 | 标签: LOG 分享到: 原文出处: xirong 一.困扰的疑惑 目前的日志框架有 jdk 自带的 log ...

  2. python3 datetime和time获取当前日期和时间

    import datetime import time # 获取当前时间, 其中中包含了year, month, hour, 需要import datetime today = datetime.da ...

  3. 文库网站建设,文库网站PHP代码,TP开发文库网

    专业定制仿百度文库网站系统,文库网站系统源码,文库‌‌网站建设开发,支持电脑版+手机版+微信版+小程序版+APP版,由10年的技术团队专业定制,需要的朋友可以联系我们.网站采用:PHP+MySQL+t ...

  4. FLINK流计算拓扑任务代码分析<二>

    首先 是 StreamExecutionEnvironment see = StreamExecutionEnvironment.getExecutionEnvironment(); 我们在编写 fl ...

  5. Chino 操作系统开发日志 (1) - 为 IoT 而生

    引言 很多人都听说过 IoT (物联网)这个词,越来越多的人在装修时开始选择智能家居,很多人也购买智能音箱做智能家居控制,想必未来一定是 AI + 物联网的时代. 一种技术要发展并走向成熟必须要降低门 ...

  6. md5.digest()与md5.hexdigest()之间的区别及转换

    举给例子 md5 = hashlib.md5('adsf') md5.digest() //返回: '\x05\xc1*(s48l\x94\x13\x1a\xb8\xaa\x00\xd0\x8a' # ...

  7. 《Java核心技术36讲》阅读笔记:Exception和Error有什么区别?

    1.Exception 和 Error有什么区别?运行时异常与一般异常有什么区别? Exception和Error都继承自java.lang.Throwable.在Java中只有Throwable的实 ...

  8. 20155325实验四 Android程序设计

    实验四 Android程序设计-1 Android Stuidio的安装测试: 参考<Java和Android开发学习指南(第二版)(EPUBIT,Java for Android 2nd)&g ...

  9. Mac下 Windows 7 虚拟机成功搭建SVN服务器后如何与Xcode建立联系,并上传原始工程的详细步骤

    内容中包含 base64string 图片造成字符过多,拒绝显示

  10. linux下,将一个目录中的图片文件合成为gif图片

    # {} 为文件所在目录位置 # {} 为gif图片位置 convert -delay -depth -layers optimize -quality -loop {} {}