zoukankan      html  css  js  c++  java
  • redis集群搭建

    redis集群功能: 

    多个redis节点网络互联,数据共享;

    所有的节点都是一主一从(可以是多个从),其中从不提供服务,仅作为备用;

    不支持同时处理多个键(如mset/mget),因为redis需要把键均匀分布在各个节点上,并发量很高的情况下同时创建键值会降低性能并导致不可预测的行为;

    支持在线增加、删除节点,客户端可以连任何一个主节点进行读写。

    redis集群原理:

    原理:redis集群设计包括2部分:哈希Slot和节点主从。

    主从主要来实现redis读写分离,一个master,N个slave,salve也可以有自己的slave,master只负责写和同步数据给slave,slave主要用于读,扩容slave只能提高读的效率。写的瓶颈以及存储容量的瓶颈都会存在。

    哈希slot其实就是分库分表,也就是负载均衡,能提高redis的并发能力,数据依次存储到各个node上面,不会有重复的数据,每个node上面的数据都不会重复,node之间也会互相监听,redis把写操作分摊到各个节点上面。

    redis集群很好的降低了并发负载压力,同时也解决了单点故障,扩展并发读就添加slave,扩展并发写以及扩容就添加master。(该master存在key name,当master挂掉之后,再次更新该name的时候,slave会变成对应的master)

    准备:

    分别在2台机器上面启动三个redis服务

    192.168.1.99,启动端口7000 7001 7002
    192.168.1.210,启动端口7003 7004 7005

    安装redis

    wget http://download.redis.io/releases/redis-3.2.0.tar.gz -p  /usr/local/src
    tar zxvf redis-3.2.0.tar.gz
    cd redis-3.2.0
    make
    make PREFIX=/usr/local/redis install

    配置redis

    mkdir /usr/local/redis/etc
    vim redis7000.conf       ##写入如下内容:
    port 7000
    bind 192.168.1.99
    daemonize yes
    pidfile /usr/local/redis/var/redis_7000.pid
    dir /data/redis/7000
    cluster-enabled yes
    cluster-config-file nodes_7000.conf
    cluster-node-timeout 10100
    appendonly yes

    说明:其它redis配置文件也如上,只需sed -i '0,$s/7000/700X/g' redis700X.conf,记得bind绑定主机要修改

    创建配置文件里面对应的目录:

    mkdir /usr/local/redis/var
    192.168.1.99机器上,mkdir -p /data/redis/{7000,7001,7002}
    192.168.1.210机器上,mkdir -p /data/redis/{7003,7004,7005}

    创建软链

    ln -s /usr/local/redis/bin/* /usr/local/bin/

    启动6个redis服务

    redis-server /usr/local/redis/etc/redis7000.conf
    ......

    安装ruby

    yum install -y ruby rubygem
    yum安装ruby默认是2.0.0版本,但gem install redis需要ruby版本大于2.2.2,可以通过重新安装ruby,我这边是直接指定版本:
    gem install redis --version 3.2.2

    创建集群

    cp /usr/local/src/redis-3.2.0/src/redis-trib.rb  /usr/bin/
    redis-trib.rb create --replicas 1 192.168.1.99:7000 192.168.1.99:7001 192.168.1.99:7002 192.168.1.210:7003 192.168.1.210:7004 192.168.1.210:7005  //会创建3master-3slave的集群(默认自动分配)

    登录

    redis-cli -c -h 192.168.1.99 -p 7000  ## -c说明以集群的方式登录,任意一个节点都可以创建key,或者查看key

    redis集群操作

    cluster nodes  //列出节点
    redis-trib.rb check 192.168.1.99:7000 //查看redis集群状态
    cluster info//查看集群信息
    cluster meet ip port //添加节点
    cluster forget node_id //移除某个节点
    cluster replicate node_id//将当前节点设置为指定节点的从
    cluster saveconfig//保存配置文件

    python连接redis集群

    1. 安装redis-py-cluster模块

    pip3 install redis-py-cluster ##我运行在python3上面

    2. 使用redis-py-cluster模块操作redis集群

    [root@master day11]# cat redis_cluster.py 
    __author__ = 'wangzai'
    from rediscluster import StrictRedisCluster
    import sys
    
    def redis_cluster():
        redis_nodes = [{'host':'192.168.1.99','port':7000},
                       {'host':'192.168.1.99','port':7001},
                       {'host':'192.168.1.99','port':7002},
                       {'host':'192.168.1.210','port':7003},
                       {'host':'192.168.1.210','port':7004},
                       {'host':'192.168.1.210','port':7005}
                      ]
        try:
            redisconn = StrictRedisCluster(startup_nodes = redis_nodes)
        except Exception as e:
            print("connect error")
            sys.exit(1)
    
        redisconn.set('name1','kk')
        print("name is", redisconn.get('name1'))
    
    
    if __name__ == "__main__":
        redis_cluster()

    说明:执行上面脚本之后,会在某一个master上面生成该key,如果该master挂掉,重新更新该key,对应slave会变成master,更新该key,如果该key的master和slave都挂掉,则数据会访问不到。不同的key会分发到不同的master上面,redis集群不仅实现了高并发、也实现了高可用。



  • 相关阅读:
    cocos2dx android java调用C++
    cocos2dx android c++调用java
    cocos2dx android collection
    cocos2dx学习之windows android环境搭建
    windows phone 8.0 与 windows phone7.1区别
    C#文件同步工具教程
    Web2.0时代,RSS你会用了吗?(技术实现总结)
    介绍一篇关于session的好文章,写的很详细(jspservlet 技术)
    利用HttpModuler实现WEB程序同一时间只让一个用户实例登陆
    css
  • 原文地址:https://www.cnblogs.com/654wangzai321/p/8082475.html
Copyright © 2011-2022 走看看