zoukankan      html  css  js  c++  java
  • redis伪集群脚本

     
    #/bin/bash
    #set -e
    
    #安装redis伪集群脚本,先把redis-5.0.4.tar.gz redis-3.2.2.gem及启动脚本放在/data1/redis-cluster目录下,然后执行该脚本即可 
    #!/bin/bash
    set -e
    #获取redis本机ip
    ip=`hostname -I`
    workspace=/data1/redis-cluster  #根据需求自定义  想在哪个目录安装就写哪个目录
    if [ ! -d $workspace ];then
            mkdir -p $workspace
    fi
    #下载并解压安装redis
    cd $workspace
    wget http://download.redis.io/releases/redis-5.0.4.tar.gz
    tar zxvf redis-5.0.4.tar.gz -C $workspace
    cd $workspace/redis-5.0.4
    make  &&  make install PREFIX=$workspace
    
    #配置redis
    cd $workspace
    mv bin redis-01
    cp $workspace/redis-5.0.4/redis.conf redis-01
    sed -i "s/^bind 127.0.0.1/bind $ip/" redis-01/redis.conf
    sed -i 's/6379/7001/g' redis-01/redis.conf
    sed -i 's/daemonize no/daemonize yes/' redis-01/redis.conf
    sed -i 's/appendonly no/appendonly yes/' redis-01/redis.conf
    sed -i 's/^# cluster-enabled/cluster-enabled/' redis-01/redis.conf
    sed -i 's/^# cluster-config-file/cluster-config-file/' redis-01/redis.conf
    sed -i 's/^# cluster-node-timeout/cluster-node-timeout/' redis-01/redis.conf
    sed -i 's/appendonly yes/appendonly no/' redis-01/redis.conf
    
    cp -r redis-01 redis-02
    cp -r redis-01 redis-03
    cp -r redis-01 redis-04
    cp -r redis-01 redis-05
    cp -r redis-01 redis-06
    
    sed -i 's/7001/7002/g' redis-02/redis.conf
    sed -i 's/7001/7003/g' redis-03/redis.conf
    sed -i 's/7001/7004/g' redis-04/redis.conf
    sed -i 's/7001/7005/g' redis-05/redis.conf
    sed -i 's/7001/7006/g' redis-06/redis.conf
    
    #启动脚本
    echo "#/bin/bash
    
    cd $workspace/redis-01  
    ./redis-server redis.conf  
    
    cd $workspace/redis-02
    ./redis-server redis.conf
    
    cd $workspace/redis-03
    ./redis-server redis.conf
    
    cd $workspace/redis-04
    ./redis-server redis.conf
    
    cd $workspace/redis-05
    ./redis-server redis.conf
    
    cd $workspace/redis-06
    ./redis-server redis.conf
    " >$workspace/all-start.sh
    
    #停止脚本
    echo "#/bin/bash
    redis-cli -h $ip -p 7001  shutdown
    redis-cli -h $ip -p 7002  shutdown
    redis-cli -h $ip -p 7003  shutdown
    redis-cli -h $ip -p 7004  shutdown
    redis-cli -h $ip -p 7005  shutdown
    redis-cli -h $ip -p 7006  shutdown
    ">$workspace/all-stop.sh
    
    #自启动脚本
    cat > /etc/init.d/redis <<EOF
    #!/bin/sh
    #
    # chkconfig: 2345 70 20
    # description: Redis-cluster autostart
    . /etc/init.d/functions
    
    case "$1" in
            start)
                    /bin/bash /data1/redis-cluster/all-start.sh
                    ;;
            stop)
                    /bin/bash /data1/redis-cluster/all-stop.sh
                    ;;
            *)
                    echo "Usage: $0 (start|stop)"
                    ;;
    esac
    EOF
    
    #启动redis
    chmod 741 $workspace/*.sh
    $workspace/all-start.sh
    sleep 3
    cp $workspace/redis-01/redis-cli /usr/bin/redis-cli
    yum install -y  expect
    #配置集群
    expect -c "
            spawn redis-cli --cluster create $ip:7001 $ip:7002 $ip:7003 $ip:7004 $ip:7005 $ip:7006 --cluster-replicas 1;
            expect "configuration" { send "yes
    "; }
            expect eof
    "
    
    echo -e "
    redis-cluster is ok "
    chkconfig redis on

    启动脚本

    单实例设置自启动脚本

    1、复制redis启动脚本

    redis启动脚本一般在redis根目录的utils,如果不知道路径,可以先查看路径

    [root@slj-redis data1]#  find / -name redis_init_script

    /data1/redis-cluster/redis-4.0.9/utils/redis_init_script

     

    复制启动脚本到/etc/init.d/redis文件中

    cp /data1/redis-cluster/redis-4.0.9/utils/redis_init_script /etc/init.d/redis-alone

    2、更改redis-alone脚本

    首先添加如下俩行

    # chkconfig: 2345 90 10

    # description: Redis is a persistent key-value database

    其次更改EXEC   CLIEXEC  CONF 为实际所安装目录即可

    REDISPORT=6379

    EXEC=/data1/redis-alone/bin/redis-server

    CLIEXEC=/data1/redis-alone/bin/redis-cli

    PIDFILE=/var/run/redis_${REDISPORT}.pid

    CONF="/data1/redis-alone/redis.conf"

    chkconfig redis-alone on

    centos7

    [Unit]
    Description=Redis
    After=network.target remote-fs.target nss-lookup.target
    
    [Service]
    Type=forking
    
    ExecStart=/usr/local/redis/src/redis-server /usr/local/redis/redis.conf
    ExecReload=/bin/kill -s HUP $MAINPID
    ExecStop=/usr/bin/redis-cli -h 127.0.0.1 -p 6379 shutdown
    
    
    
    [Install]
    WantedBy=multi-user.target

    集群设置自启动

    先写好集群启动脚本

    [root@slj-redis redis-cluster]# cat all-start.sh

    cd /data1/redis-cluster/redis-01 
    
    ./redis-server redis.conf 
    
     
    
    cd /data1/redis-cluster/redis-02
    
    ./redis-server redis.conf
    
     
    
    cd /data1/redis-cluster/redis-03
    
    ./redis-server redis.conf
    
     
    
    cd /data1/redis-cluster/redis-04
    
    ./redis-server redis.conf
    
     
    
    cd /data1/redis-cluster/redis-05
    
    ./redis-server redis.conf
    
     
    
    cd /data1/redis-cluster/redis-06
    
    ./redis-server redis.conf

    关闭脚本

    [root@slj-redis redis-cluster]# vim all-stop.sh

    redis-cli -h 10.253.0.1 -p 7001  shutdown
    
    redis-cli -h 10.253.0.1 -p 7002  shutdown
    
    redis-cli -h 10.253.0.1 -p 7003  shutdown
    
    redis-cli -h 10.253.0.1 -p 7004  shutdown
    
    redis-cli -h 10.253.0.1 -p 7005  shutdown
    
    redis-cli -h 10.253.0.1 -p 7006  shutdown

    [root@slj-redis init.d]# vim redis-cluster

    #!/bin/sh
    
    #
    
    # chkconfig: 2345 70 20
    
    # description: Redis-cluster autostart
    
    . /etc/init.d/functions
    
     
    
     
    
    case "$1" in
    
        start)
    
            /bin/bash /data1/redis-cluster/all-start.sh
    
            ;;
    
        stop)
    
            /bin/bash /data1/redis-cluster/all-stop.sh
    
            ;;
    
        *)
    
            echo "Usage: $0 (start|stop)"
    
            ;;
    
    esac
    
     
    
     
    
    chkconfig redis-cluster on

    批量删除key

    redis-cli -h <host> -a <password> keys "<key>" | xargs redis-cli -h <host> -a <password> del
  • 相关阅读:
    java EL表达式中${param.name}详细
    javascript中常用坐标属性offset、scroll、client
    Oralce if ..elsif结构
    VS2013 字符串函数与VC不兼容问题解决方法
    Directory Instruction
    Timestamp
    GetCurrentTime() and CFile option
    MessageBox 参数说明
    单片机红外线接收算法
    IAR for MPS430 V7.12.1 编程规范
  • 原文地址:https://www.cnblogs.com/zphqq/p/10239323.html
Copyright © 2011-2022 走看看