摘抄并用于自己后查

单机版的配置: 

  1. 下载redis压缩包,然后解压缩文件(tar xzf);

  2. 进入解压后的redis文件目录,编译redis源文件(make,没有c环境要gcc);

  3. 把编译好的redis源文件安装到/usr/local/redis目录下,如果/local目录下没有redis目录,会自动新建redis目录;

  4. 进入/usr/local/redis/bin 目录,直接 ./redis-server启动redis(此时为前端启动redis);

  5. 将redis启动方式改为后端启动,具体做法:把解压缩的redis文件下的 redis.conf文件复制到/usr/local/redis/bin目录下,然后修改redis.conf文件 ->daemonize:no 改为yes

  6. 在/bin目录下通过./redis-server redis.conf启动redis (此为后台启动)

集群配置:

  一、Redis Cluster(Redis集群)简介

    1)redis3.0版本之前只支持单例模式,在3.0版本后才支持集群。

    2)redis集群采用P2P模式,是完全去中心化的,不存在中心节点或者代理节点。

    3)redis集群是没有统一的入口,客户端连接集群时,连接的是集群中的任意节点即可,集群内部的节点是相互通信(PING-PONG机制),每个节点都是一个redis实例。

    4)为了实现集群的高可用,即判断节点是否能正常使用,redis-cluster有一个投票容错机制:如果集群中超过半数的节点投票认为某个节点挂了,那么这个节点就是挂了(fail),这是判断节点是否挂了的方法。

    5)那么如果判断集群是否挂了呢? -> 如果集群中任意一个节点挂了,而且该节点没有从节点(备份节点),那么这个集群就是挂了。这个是判断集群是否挂了的方法。

    6)为什么任一节点挂了集群就是挂了呢? -> 因为集群内置了16384个slot(哈希槽),并且把所有的物理节点映射到这个16384[0-16383]个slot上,或者说把这些slot均等分配给了各节点。当需要在redis集群存放一个数据(key-value)时,redis会先对这个key做crc16算法,然后得到一个结果。再把这个结果对16384进行取余,这个余数会对应[0-16383]其中一个槽,进而决定key-value存储到哪个节点。所以一旦某个节点挂了,该节点对应的slot就无法使用,那么就会导致集群无法正常工作。读取时,也是先对这个key做crc16和取余得到对应存放的节点。

    7)综上,每个redis集群理论上最多可以有16384个节点。

  二、集群搭建需要的环境

   1)redis集群至少需要3个节点,因为投票容错机制要求超过半数节点认为某个节点挂了,该节点才是挂了,所以2个节点无法构成集群。

   2)要保证集群的高可用,需要每个节点都有从节点,也就是备份节点,所以redis集群至少需要6台服务器。

  

  三、集群搭建具体步骤

  安装环境和版本:centos7 , redis5.0.5。redis版本在5之前的集群需要安装ruby环境(这很耗时间,且有各种问题需要解决),redis5.0.0之后已经将redis-trib.rb 脚本的功能全部集成到redis-cli之中了。本文基于redis-cli的-cluster来搭建集群。

  

  安装过程:

   1. 下载并解压(为方便直接从上面单机版的将文件夹拷贝过来)

  2. 编译安装:

    make && make install

   3.创建redis节点

    在 /opt/redis-cluster/redis-5.0.5 下创建 redis_cluster文件夹,同时在里面创建redis7001,redis7002,redis7003,redis7004,redis7005,redis7006文件夹,并将redis.cof文件夹分别复制到这6个文件夹内,分别修改这个6个配置文件,修改内容如下:

    port 7001       // 端口7001,7002,7003,7004,7005,7006

    bind 本机ip     //本地时192.168.80.131

    daemonize yes   // 设置redis后台运行

    pidfile /var/run/redis_7001.pid   // pidfile文件对应7001 ... 7006

    cluster-enable yes  // 开区集群,把注释去掉

    cluster-config-file nodes_7001.conf  // 集群的配置,配置文件首次启动自动生成

    cluster-node-timeout 15000  // 请求超时,默认15秒,可自行设置

    appendonly yes  // aof日志开启,有需要就开启,时间长了文件会很大

  4. 启动各节点:可以搞个批处理文件 startup.sh

    

    

  5. 检查redis启动情况

     ps -aux|grep redis

    netstat -tnlp|grep redis

    

    如果少了哪个,检查是否配置文件修改时出错

  6. 创建集群

     $ redis-cli --cluster create 192.168.80.131:7001 192.168.80.131:7002 192.168.80.131:7003 192.168.80.131:7004 192.168.80.131:7005 192.168.80.131:7006 --cluster-replicas 1

    

 

 --cluster-replicas 1 命令的意思是:一主一从配置,六个节点就是三主三从

  使用如下命令创建集群的状态:

  redis-cli --cluster check 192.168.80.131:7001  #填写任意节点即可

  

  

最新文章

  1. Canvas电子签名和游戏化
  2. 求height数组
  3. trigger() & bind() 使用心得
  4. 【BZOJ-3293&1465&1045】分金币&糖果传递×2 中位数 + 乱搞
  5. UVA 10054 The Necklace(欧拉回路,打印路径)
  6. css改变滚动条样式
  7. input type=button设置高度不管用
  8. HTML5初步了解
  9. linux shadowsocket 安装和启动
  10. 6.3 Query 语句对系统性能的影响
  11. discuss!X3.4 帖子显示昵称而不是用户名的解决办法
  12. STL库学习笔记(待补充QAQ
  13. 聊聊 Nginx 的反向代理
  14. FFmpeg4.0笔记:file2rtmp
  15. 软件包管理:rpm命令管理-安装升级与卸载
  16. Jenkins之构建执行脚本权限问题
  17. Java之JVM调优案例分析与实战(4) - 外部命令导致系统缓慢
  18. HDU3068:最长回文(Manacher模板)
  19. C#DataTable与Model互转
  20. 张量 (tensor) 是什么?

热门文章

  1. HDU6438 Buy and Resell 2018CCPC网络赛 -低买高卖-贪心经典题
  2. gnome/KDE安装,gnome出现问题,重新安装nvdia驱动, Linux(CentOS7) NVIDIA GeForece GTX 745 显卡驱动
  3. LeetCode 176. Second Highest Salary (第二高的薪水)
  4. Day 7 :一句话Python(匿名函数-lambda,三元运算,列表表达式,生成器表达式)
  5. seo具备的条件
  6. 13-Ubuntu-查阅终端命令版本信息和帮助信息
  7. springcloud(十六):服务网关zuul (2)
  8. Flask-session用法
  9. table 单列宽度设置
  10. 2019-6-23-WPF-解决弹出模态窗口关闭后,主窗口不在最前