0
点赞
收藏
分享

微信扫一扫

Redis安裝、启动与集群搭建

鲤鱼打个滚 2021-09-26 阅读 40
javaLinux

安装

安装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下的文件列表

说明:

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

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

启动

前端模式启动

后端模式启动

  • 修改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. 集群原理


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

redis-cluster投票:容错


  • (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
举报

相关推荐

0 条评论