美文网首页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