Redis安装和Redis-Cluster搭建

Redis安装

  1. Redis是c语言开发的。安装redis需要c语言的编译环境。如果没有gcc需要在线安装。

    yum install gcc-c++

  2. Redis下载地址: https://redis.io/download
    将下载好的安装包上传到linux, 解压

    tar zxf redis-3.2.12.tar.gz

    进入redis-3.2.12目录进行编译

    cd redis-3.2.12
    make

    编译完成后进行安装(这里安装到了/export/server/redis)

    make install PREFIX=/export/server/redis

  3. 启动Redis

  • 前端启动
    在usr/local/redis/bin目录下
    > ./redis-server

    使用Ctrl+c关闭

  • 后台启动
    将文件redis.conf复制到redis/bin

    cp /root/redis-3.2.12 //export/server/redis/bin

    修改redis.conf文件

    vim redis.conf

    找到 daemonize no 修改为 daemonize yes

    在redis/bin目录下使用配置文件启动

    ./redis-server redis.conf

    查看进程中是否有redis-server

    ps aux|grep redis

    停止, 可以直接杀死进程, 或者在redis的bin目录下

    ./redis-cli shutdown

  1. 连接redis的客户端
    首先运行redis
    连接到redis服务
    1 ) 连接本地

    ./redis-cli

    2 ) 连接远程

    ./redis-cli -h node1 -p 6379

    -h ip地址(这里配置了hosts文件)
    -p 端口号(默认6379)

    解决中文乱码问题:

    ./redis-cli -h 192.168.25.129 -p 6379 --raw

    3 ) 连接服务后查看状态
    连接好后输入: ping
    显示PONG表示正常

    4 ) 可能遇到远程无法连接的问题
    修改redis.conf文件
    注释掉bind 127.0.0.1, #bind 127.0.0.1
    protected-mode yes 改为 protected-mode no

Redis的使用

  1. 数据类型
  • String:key-value(做缓存)
    操作方法:
    set key value
    get key
    del key
    incr key增1
    decr key减1
  • Hash:key-fields-values(做缓存, key不能重复)
    操作方法:
    hset key1 key2 value
    hdel key1 key2删除某个键值对
    hdel key1 删除整个hash
    hget key1 key2
    hgetall key1查看hash中所有的数据
    hlen key1查看整个hash的长度
  • List:有顺序可重复
    操作方法:
    lpush key value value…左端填入
    rpush key value value…右端填入
    lpop key左端取出
    rpop key右端取出
    blpop key timeout左侧取出,timeout超时时间
    brop
    其他操作: lpushx, rpushx,lrem
  • Set:无顺序,不能重复
  • SortedSet(zset):有顺序,不能重复

Redis-Cluster

简介

通过集群实现扩容
3.0版本后支持redis-cluster集群,它是Redis官方提出的解决方案,Redis-Cluster采用无中心结构,每个节点保存数据和整个集群状态,每个节点都和其他所有节点连接。其redis-cluster架构图如下:
在这里插入图片描述
客户端与 redis 节点直连,不需要中间 proxy 层.客户端不需要连接集群所有节点连接集群中任何一个可用节点即可。
所有的 redis 节点彼此互联(PING-PONG 机制),内部使用二进制协议优化传输速度和带宽.

分布存储机制-槽
  • redis-cluster 把所有的物理节点映射到[0-16383]slot 上,cluster 负责维护
    node <-> slot <-> value
  • Redis 集群中内置了 16384 个哈希槽
    当需要在 Redis 集群中放置一个 key-value 时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点。
容错机制-投票
  • 选举过程是集群中所有master参与,如果半数以上master节点与故障节点通信超过(cluster-node-timeout),认为该节点故障,自动触发故障转移操作. 故障节点对应的从节点自动升级为主节点
  • 如果集群任意master挂掉,且当前master没有slave.集群进入fail状态,也可以理解成集群的slot映射[0-16383]不完成时进入fail状态.
    在这里插入图片描述
Redis-Cluster搭建
  1. 需要 6 台 redis 服务器分别装好Redis

  2. 需要使用ruby脚本来实现集群搭建
    yum命令安装 ruby:

    yum install ruby
    yum install rubygems

  3. 修改redis.conf配置文件
    cluster-enabled yes 前的注释(#)去掉

  4. 启动每台服务器上的Redis

  5. 上传redis-3.0.0.gem

    gem install redis-3.0.0.gem

  6. 使用 ruby 脚本搭建集群

    ./redis-trib.rb create --replicas 1 node1:6379 nide2:6379 node3:6379
    node4:6379 node5:6379 node6:6379

    当运行完成并出现 [OK] All 16384 slots covered , 集群搭建就成功了

  7. 连接Redis-Cluster

    redis-cli -h 主机ip -p 端口 -c

    -c:代表连接的是 redis 集群

    集群模式的存取可在任意节点进行
    集群模式下存入的数据在非集群模式下无法取出

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值