美文网首页Linux
Redis安裝、启动与集群搭建

Redis安裝、启动与集群搭建

作者: MisterDo | 来源:发表于2019-10-24 18:53 被阅读0次

    安装

    redis是C语言开发,建议在linux上运行,本教程使用Centos6.4作为安装环境。

    安装redis需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc:

    yum install gcc-c++
    
    • 版本说明
      本教程使用redis3.0版本。3.0版本主要增加了redis集群功能。
    • 源码下载
      官网下载 将redis-3.0.0.tar.gz拷贝到/usr/local下
    • 解压源码
    tar -zxvf redis-3.0.0.tar.gz
    
    • 进入解压后的目录进行编译
    cd /usr/local/redis-3.0.0
    make
    

    安装到指定目录,如 /usr/local/redis

    cd /usr/local/redis-3.0.0
    make PREFIX=/usr/local/redis install
    
    • redis.conf
      redis.conf是redis的配置文件,redis.conf在redis源码目录。
      注意修改port作为redis进程的端口,port默认6379。

    • 拷贝配置文件到安装目录下
      进入源码目录,里面有一份配置文件 redis.conf,然后将其拷贝到安装路径下

    cd /usr/local/redis
    mkdir conf
    cp /usr/local/redis-3.0.0/redis.conf  /usr/local/redis/bin
    
    • 安装目录bin下的文件列表
    • 安装目录bin下的文件列表

    说明:

    文件名 说明
    redis-server redis服务器
    redis-cli redis命令行客户端
    redis-benchmark redis性能测试工具
    redis-check-aof AOF 文件修复工具
    redis-check-dump RDB 文件检查工具

    redis3.0新增的redis-sentinel是redis集群管理工具可实现高可用

    启动

    前端模式启动

    直接运行bin/redis-server将以前端模式启动,前端模式启动的缺点是ssh命令窗口关闭则redis-server程序结束,不推荐使用此方法

    后端模式启动

    • 修改redis.conf配置文件, daemonize yes 以后端模式启动
    • 执行如下命令启动redis:
    cd /usr/local/redis
    ./bin/redis-server ./redis.conf
    

    redis默认使用6379端口

    外部连接不上redis的解决方法

    由于linux防火墙默认开启,redis的服务端口6379并不在开放规则之内,所有需要将此端口开放访问或者关闭防火墙。

    • 关闭防火墙命令:
      sevice iptables stop
    • 如果是修改防火墙规则,可以修改:/etc/sysconfig/iptables文件

    redis集群

    3.1. 集群原理

    • redis集群原理.PNG
      架构细节:
    • (1)所有的redis节点彼此互联(PING-PONG机制),内部使用二进制协议优化传输速度和带宽.
    • (2)节点的fail是通过集群中超过半数的节点检测失效时才生效.
    • (3)客户端与redis节点直连,不需要中间proxy层.客户端不需要连接集群所有节点,连接集群中任何一个可用节点即可
    • (4)redis-cluster把所有的物理节点映射到[0-16383]slot上,cluster 负责维护node<->slot<->value

    Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value 时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个 key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点

    redis-cluster投票:容错

    • redis容错.PNG

      (1)领着投票过程是集群中所有master参与,如果半数以上master节点与master节点通信超过(cluster-node-timeout),认为当前master节点挂掉.
      (2):什么时候整个集群不可用(cluster_state:fail)?
      a:如果集群任意master挂掉,且当前master没有slave.集群进入fail状态,也可以理解成集群的slot映射[0-16383]不完成时进入fail状态. ps : redis-3.0.0.rc1加入cluster-require-full-coverage参数,默认关闭,打开集群兼容部分失败.
      b:如果集群超过半数以上master挂掉,无论是否有slave集群进入fail状态.
      ps:当集群不可用时,所有对集群的操作做都不可用,收到((error) CLUSTERDOWN The cluster is down)错误

    ruby环境

    redis集群管理工具redis-trib.rb依赖ruby环境,首先需要安装ruby环境:
    安装ruby

    yum install ruby
    yum install rubygems
    

    安装ruby和redis的接口程序
    拷贝redis-3.0.0.gem至/usr/local下
    执行:

    gem install /usr/local/redis-3.0.0.gem
    

    创建集群

    集群结点规划

    • 这里在同一台服务器用不同的端口表示不同的redis服务器,如下:
      主节点:
      10.28.146.111:7001
      10.28.146.111:7002
      10.28.146.111:7003
      从节点:
      10.28.146.111:7004
      10.28.146.111:7005
      10.28.146.111:7006
    • 在/usr/local下创建redis-cluster目录,其下创建7001、7002。。7006目录.
    • 将redis安装目录bin下的文件拷贝到每个700X目录内,同时将redis源码目录src下的redis-trib.rb拷贝到redis-cluster目录下。
    • 修改每个700X目录下的redis.conf配置文件:
    port XXXX
    #bind 10.28.146.111
    cluster-enabled yes 
    

    启动每个结点redis服务

    分别进入7001、7002、...7006目录,执行:

    ./redis-server ./redis.conf
    

    相关文章

      网友评论

        本文标题:Redis安裝、启动与集群搭建

        本文链接:https://www.haomeiwen.com/subject/chsrvctx.html