redis.conf配置文件中daemonize守护线程,默认是NO。
daemonize是用来指定redis是否要用守护线程的方式启动。
redis采用的是单进程多线程的模式。当redis.conf中选项daemonize设置成yes时,代表开启守护进程模式。在该模式下,redis会在后台运行,并将进程pid号写入至redis.conf选项pidfile设置的文件中,此时redis将一直运行,除非手动kill该进程。
当daemonize选项设置成no时,当前界面将进入redis的命令行界面,exit强制退出或者关闭连接工具(putty,xshell等)都会导致redis进程退出。
所有备份都分两种情况,一种是快照,一种是备份
客户端执行save命令----》redis服务端----》同步创建RDB二进制文件,如果老的RDB存在,会替换老的
客户端执行save命令----》redis服务端----》异步创建RDB二进制文件,如果老的RDB存在,会替换老的
- save 900 1
- save 300 10
- save 60 10000
- # 如果60s中改变了1w条数据,自动生成rdb
- # 如果300s中改变了10条数据,自动生成rdb
- # 如果900s中改变了1条数据,自动生成rdb
AOF的三种策略 :
always:redis–》写命令刷新的缓冲区—》每条命令fsync到硬盘—》AOF文件
everysec(默认值):redis——》写命令刷新的缓冲区—》每秒把缓冲区fsync到硬盘–》AOF文件
no:redis——》写命令刷新的缓冲区—》操作系统决定,缓冲区fsync到硬盘–》AOF文件
-本质:本质就是把过期的,无用的,重复的,可以优化的命令,来优化
在客户端主动输入:bgrewriteaof
- # AOF持久化配置最优方案
- appendonly yes #将该选项设置为yes,打开
- appendfilename "appendonly.aof" # 文件保存的名字
- appendfsync everysec # 采用第二种策略
- dir ./data # 存放的路径
- no-appendfsync-on-rewrite yes # 在aof重写的时候,是否要做aof的append操作,因为aof重写消耗性能,磁盘消耗,正常aof写磁盘有一定的冲突,这段期间的数据,允许丢失
Redis全量复制一般发生在Slave初始化阶段,这时Slave需要将Master上的所有数据都复制一份。具体步骤如下:
Redis增量复制是指Slave初始化后开始正常工作时主服务器发生的写操作同步到从服务器的过程。
增量复制的过程主要是主服务器每执行一个写命令就会向从服务器发送相同的写命令,从服务器接收并执行收到的写命令。
主从刚刚连接的时候,进行全量同步;全同步结束后,进行增量同步。当然,如果有需要,slave 在任何时候都可以发起全量同步。redis 策略是,无论如何,首先会尝试进行增量同步,如不成功,要求从机进行全量同步。
在从库执行
SLAVEOF 127.0.0.1 6379
断开关系
slaveof no one
- slaveof 127.0.0.1 6379
- slave-read-only yes
让redis的主从复制高可用
- #创建三个配置文件:
- #第一个是主配置文件
- daemonize yes
- pidfile /var/run/redis.pid
- port 6379
- dir "/opt/soft/redis/data"
- logfile “6379.log”
-
- #第二个是从配置文件
- daemonize yes
- pidfile /var/run/redis2.pid
- port 6378
- dir "/opt/soft/redis/data2"
- logfile “6378.log”
- slaveof 127.0.0.1 6379
- slave-read-only yes
- #第三个是从配置文件
- daemonize yes
- pidfile /var/run/redis3.pid
- port 6377
- dir "/opt/soft/redis/data3"
- logfile “6377.log”
- slaveof 127.0.0.1 6379
- slave-read-only yes
-
-
- #把三个redis服务都启动起来
- ./src/redis-server redis_6379.conf
- ./src/redis-server redis_6378.conf
- ./src/redis-server redis_6377.conf
-
-
- 2 搭建哨兵
- # sentinel.conf这个文件
- # 把哨兵也当成一个redis服务器
- 创建三个配置文件分别叫sentinel_26379.conf sentinel_26378.conf sentinel_26377.conf
-
- # 当前路径下创建 data1 data2 data3 个文件夹
- #内容如下(需要修改端口,文件地址日志文件名字)
- port 26379
- daemonize yes
- dir ./data3
- protected-mode no
- bind 0.0.0.0
- logfile "redis_sentinel3.log"
- # 该行的意思是:监控的master的名字叫做mymaster (可以自定义),
- # 地址为192.168.88.111:6379,行尾最后的一个2代表在sentinel集群中,
- # 多少个sentinel认为master死了,才能真正认为该master不可用了。
- sentinel monitor mymaster 127.0.0.1 6379 2
- # 需要失效多少时间,一个主才会被哨兵认为宕机
- sentinel down-after-milliseconds mymaster 30000
- # 在主从切换时,有多少个从。可以对新的主进行同步,数字越小,完成备份的时间就越长,一般为1即可
- sentinel parallel-syncs mymaster 1
- # 同一个哨兵对一个主两次通信的最大的时间间隔
- sentinel failover-timeout mymaster 180000
-
-
- #启动三个哨兵
- ./src/redis-sentinel sentinel_26379.conf
- ./src/redis-sentinel sentinel_26378.conf
- ./src/redis-sentinel sentinel_26377.conf
-
-
-
- # 登陆哨兵
- ./src/redis-cli -p 26377
- # 输入 info
-
- # 查看哨兵的配置文件被修改了,自动生成的
-
- # 主动停掉主redis 6379,哨兵会自动选择一个从库作为主库
- redis-cli -p 6379
- shutdown
- #等待原来的主库启动,该主库会变成从库
- import redis
- from redis.sentinel import Sentinel
-
- # 连接哨兵服务器(主机名也可以用域名)
- # 10.0.0.101:26379
- sentinel = Sentinel([('10.0.0.101', 26379),
- ('10.0.0.101', 26378),
- ('10.0.0.101', 26377)
- ],
- socket_timeout=5)
-
- print(sentinel)
- # 获取主服务器地址
- master = sentinel.discover_master('mymaster')
- print(master)
-
- # 获取从服务器地址
- slave = sentinel.discover_slaves('mymaster')
- print(slave)
-
-
-
- ##### 读写分离
- # 获取主服务器进行写入
- # master = sentinel.master_for('mymaster', socket_timeout=0.5)
- # w_ret = master.set('foo', 'bar')
-
- # slave = sentinel.slave_for('mymaster', socket_timeout=0.5)
- # r_ret = slave.get('foo')
- # print(r_ret)
# to do