一.redis持久化RDB

1.在配置文件中添加参数,开启rdb功能

redis.conf 写入

port 6379
daemonize yes
logfile /data/6379/redis.log
dir /data/6379
dbfilename s15.rdb
save 900 1 #rdb机制 每900秒 有1个修>改记录
save 300 10 #每300秒 10个修改
记录
save 60 10000 #每60秒内 10000修>改记录

创建文件夹

mkdir -p /data/6379

2.开启redis服务端,测试rdb功能

redis-server redis.conf

二.redis持久化之aof

1.开启aof功能,在redis.conf中添加参数

port 6379
daemonize yes
logfile /data/6379/redis.log
dir /data/6379
#后面区分添加的两行代码
appendonly yes
appendfsync everysec

2.启动redis服务端,指定aof功能,测试持久化数据

三.redis不重启之rdb数据切换到aof数据

1.准备rdb的redis服务端 redis-server s15-redis.conf (注明这是在rdb持久化模式下)

2.切换rdb到aof

redis-cli 登录redis,然后通过命令,激活aof持久化

3.127.0.0.1:6379> CONFIG set appendonly yes   #用命令激活aof持久化(临时生效,注意写入到配置文件)

4.127.0.0.1:6379> CONFIG SET save "" #关闭rdb持久化

5.将aof操作,写入到配置文件,永久生效,下次重启后生效

 port 6379
daemonize yes
logfile /data/6379/redis.log
dir /data/6379
#dbfilename s15.rdb
#save 900 1
#save 300 10
#save 60 10000
appendonly yes
appendfsync everysec

6.测试aof数据持久化 ,杀掉redis,重新启动

kill 杀死进程

redis-server s15-redis.conf

7.写入数据,检查aof文件

四 redis的主从同步

1.检查redis数据库信息,主从状态的命令

redis-cli -p 6379 info 检查数据库信息

redis-cli -p 6379 info replication 检查数据库主从信息

1.准备三个redis配置文件,通过端口的区分,启动三个redis数据库实例,然后配置主从复制

redis-6379.conf

 port 6379
daemonize yes
pidfile /data/6379/redis.pid
loglevel notice
logfile "/data/6379/redis.log"
dbfilename dump.rdb
dir /data/6379

redis-6380.conf

#通过命令快速生成配置文件

sed "s/6379/6380/g" redis-6379.conf > redis-6380.conf

slaveof 127.0.0.1 6379 #指明主库的身份ip 和端口  #这步需要进入redis-cli -p -6380 后

同上创建redis-6381.conf

2.启动三个数据库实例,检测redis主从同步方案

3.redis主从赋值,故障手动切换,

3.1.杀死6379的主库实例  #这里发现从库无法创建redis

3.2.手动切换主从身份
    1.登录 redis-6380 ,通过命令,去掉自己的从库身份,等待连接
        slaoveof no one  
    2.登录redis-6381 ,通过命令,生成新的主任
        slaveof 127.0.0.1 6380

3.3.测试新的主从数据同步

五 redis哨兵

1.什么是哨兵呢?保护redis主从集群,正常运转,当主库挂掉之后,自动的在从库中挑选新的主库,进行同步

2.redis哨兵的安装配置

2.1 准备三个redis数据库实例(三个配置文件,通过端口区分)

[root@localhost redis-4.0.10]# redis-server redis-6379.conf

[root@localhost redis-4.0.10]# redis-server redis-6380.conf

[root@localhost redis-4.0.10]# redis-server redis-6381.conf

2.2.准备三个哨兵,准备三个哨兵的配置文件(仅仅是端口的不同26379,26380,26381)

redis-sentinel-26379.conf

 port 26379
dir /var/redis/data/
logfile "26379.log"
sentinel monitor s15master 127.0.0.1 6379 2
sentinel down-after-milliseconds s15master 30000
sentinel parallel-syncs s15master 1
sentinel failover-timeout s15master 180000
daemonize yes

redis-sentinel-26380.conf

快速生成文件

sed "s/26379/26380/g" redis-sentinel-26379.conf >  redis-sentinel-26380.conf

redis-sentinel-26381.conf

快速生成文件

sed "s/26379/26381/g" redis-sentinel-26379.conf >  redis-sentinel-26381.conf

3.添加后台运行参数,使得三个哨兵进程,后台运行

[root@localhost redis-4.0.10]# echo "daemonize yes" >> redis-sentinel-26379.conf

[root@localhost redis-4.0.10]# echo "daemonize yes" >> redis-sentinel-26380.conf

[root@localhost redis-4.0.10]# echo "daemonize yes" >> redis-sentinel-26381.conf

4.启动三个哨兵

redis-sentinel redis-sentinel-26379.conf
 redis-sentinel redis-sentinel-26380.conf
 redis-sentinel redis-sentinel-26381.conf

5.检查哨兵的通信状态

redis-cli -p 26379  info sentinel

查看结果如下之后,表示哨兵正常
    [root@localhost redis-4.0.10]# redis-cli -p 26379  info sentinel
    # Sentinel
    sentinel_masters:1
    sentinel_tilt:0
    sentinel_running_scripts:0
    sentinel_scripts_queue_length:0
    sentinel_simulate_failure_flags:0
    master0:name=s15master,status=ok,address=127.0.0.1:6381,slaves=2,sentinels=3


6.杀死一个redis主库,6379节点,等待30s以内,检查6380和6381的节点状态
kill 6379主节点
redis-cli -p 6380 info replication
redis-cli -p 6381 info replication
如果切换的主从身份之后,(原理就是更改redis的配置文件,切换主从身份)

7.恢复6379节点的数据库,查看是否将6379添加为新的slave身份

六 redis-cluster安装配置

1.准备6个redis数据库实例,准备6个配置文件redis-{7000....7005}配置文件

-rw-r--r-- 1 root root 151 Jan 2 19:26 redis-7000.conf

-rw-r--r-- 1 root root 151 Jan 2 19:27 redis-7001.conf

-rw-r--r-- 1 root root 151 Jan 2 19:27 redis-7002.conf

-rw-r--r-- 1 root root 151 Jan 2 19:27 redis-7003.conf

-rw-r--r-- 1 root root 151 Jan 2 19:27 redis-7004.conf

-rw-r--r-- 1 root root 151 Jan 2 19:27 redis-7005.conf

redis.conf

 port 7000
daemonize yes
dir "/opt/redis/data"
logfile "7000.log"
dbfilename "dump-7000.rdb"
cluster-enabled yes #开启集群模式
cluster-config-file nodes-7000.conf  #集群内部的配置文件
cluster-require-full-coverage no  #redis cluster需要16384个slot都正常的时候才能对外提供服务,换句话说,只要任何一个slot异常那么整个cluster不对外提供服务。 因此生产环境一般为no

2.启动6个redis数据库实例

[root@localhost s15rediscluster]# redis-server redis-7000.conf [root@localhost s15rediscluster]# redis-server redis-7001.conf [root@localhost s15rediscluster]# redis-server redis-7002.conf [root@localhost s15rediscluster]# redis-server redis-7003.conf [root@localhost s15rediscluster]# redis-server redis-7004.conf [root@localhost s15rediscluster]# redis-server redis-7005.conf

3.配置ruby语言环境,脚本一键启动redis-cluster

1.下载ruby语言的源码包,编译安装 wget https://cache.ruby-lang.org/pub/ruby/2.3/ruby-2.3.1.tar.gz

2.解压缩 ./configure --prefix=/opt/ruby/ 释放makefile make && make install 编译且安装

3.下载安装ruby操作redis的模块包 wget http://rubygems.org/downloads/redis-3.3.0.gem

3.1 gem install redis    选yes

4.配置ruby的环境变量
echo $PATH

vim /etc/profile
写入最底行
PATH=$PATH:/opt/ruby/bin/
读取文件
source /etc/profile

5.通过ruby的包管理工具去安装redis包,安装后会生成一个redis-trib.rb这个命令
一键创建redis-cluster 其实就是分配主从关系 以及 槽位分配 slot槽位分配
/opt/redis-4.0.10/src/redis-trib.rb create --replicas 1 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005

6.检查节点主从状态
redis-cli -p 7000  info replication

7.向redis集群写入数据,查看数据流向
redis-cli  -c -p 7000    #这里会将key自动的重定向,放到某一个节点的slot槽位中
set  name  s15
set  addr shahe 

linux (07) redis详解的更多相关文章

  1. Linux /dev目录详解和Linux系统各个目录的作用

    Linux /dev目录详解(转http://blog.csdn.net/maopig/article/details/7195048) 在linux下,/dev目录是很重要的,各种设备都在下面.下面 ...

  2. linux iostat命令详解 磁盘操作监控工具

    Linux系统中的 iostat是I/O statistics(输入/输出统计)的缩写,iostat工具将对系统的磁盘操作活动进行监视. 它的特点是汇报磁盘活动统计情况,同时也会汇报出CPU使用情况. ...

  3. Linux find命令详解

    转自Linux find命令详解 一.find 命令格式 1.find命令的一般形式为: find pathname -options [-print -exec -ok ...] 2.find命令的 ...

  4. Linux curl 命令详解

    命令概要 该命令设计用于在没有用户交互的情况下工作. curl 是一个工具,用于传输来自服务器或者到服务器的数据.「向服务器传输数据或者获取来自服务器的数据」 可支持的协议有(DICT.FILE.FT ...

  5. Redis详解(二)——AOF

    Redis详解(二)--AOF 前言 RDB 持久化存在一个缺点是一定时间内做一次备份,如果redis意外down掉的话,就会丢失最后一次快照后的所有修改(数据有丢失).对于数据完整性要求很严格的需求 ...

  6. 基础拾遗------redis详解

    基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...

  7. linux awk命令详解

    linux awk命令详解 简介 awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分 ...

  8. Linux启动过程详解(inittab、rc.sysinit、rcX.d、rc.local)

    启动第一步--加载BIOS 当你打开计算机电源,计算机会首先加载BIOS信息,BIOS信息是如此的重要,以至于计算机必须在最开始就找到它.这是因为BIOS中包含了CPU的相关信息.设备启动顺序信息.硬 ...

  9. Linux启动过程详解

    Linux启动过程详解 附上两张图,加深记忆 图1: 图2: 第一张图比较简洁明了,下面对第一张图的步骤进行详解: 加载BIOS 当你打开计算机电源,计算机会首先加载BIOS信息,BIOS信息是如此的 ...

随机推荐

  1. 数据分析三剑客 numpy,oandas,matplotlib

    数据分析: 是不把隐藏在看似杂乱无章的数据域背后的信息提炼出来,总结出所研究对象内在规律 NumPy(Numerical Python) 是 Python 语言的一个扩展程序库,支持大量的维度数组与矩 ...

  2. luoguP3979 遥远的国度

    换根的树剖 https://www.luogu.org/problem/P3979 题意: (出题人口活好.... 给定一棵以 root 为根的 n 个点的有根树,对于任意一个点 x, 给定他 的点权 ...

  3. 浅谈this指向问题

    链接地址:https://www.jianshu.com/p/34572435b5d0

  4. 剑指Offer-21.栈的压入、弹出序列(C++/Java)

    题目: 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈 ...

  5. vue项目搭建介绍01

    目录 vue项目搭建介绍01 vue 项目框架环境搭建: 创建项目: vue 项目创建流程: vue项目搭建介绍01 vue 项目框架环境搭建: vue 项目框架: vue django(类似)(vu ...

  6. Python Dataframe 分组排序和 Modin

    Python Dataframe 分组排序和 Modin 1.按照其中一列进行排序 在dataframe中,按照其中的一列排序:比如q值倒排 (1)rank方法 data['new_rank'] = ...

  7. JAVA基础系列:反射

    1. 定义 在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法:这 种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制. ...

  8. 对象查询语言(OQL)的应用实例

    一.绪论 两个多星期前,我的导师布置了一道作业,就是利用对象查询语言(OQL)对常规的SQL需求进行求解.而对于我一个在面向对象数据库方面,经验可谓无足轻重的新手来说,确实难以下手.不用说,我肯定在拿 ...

  9. golang基础之初识

    golang 简介 很久以前,有一个IT公司,这公司有个传统,允许员工拥有20%自由时间来开发实验性项目.在2007的某一天,公司的几个大牛,正在用c++开发一些比较繁琐但是核心的工作,主要包括庞大的 ...

  10. 【模板】gcd和exgcd

    1. gcd: int gcd(int a,int b) { return !b?a:gcd(b,a%b); } exgcd: int exgcd(int a,int b,int& x,int ...