RedisCluster管理脚本

原创 2018年04月16日 10:33:06

安装好redis后在脚本中配置好IP和redis-trib.rb的路径,然后执行./create-cluster start就可以创建6个redis实例,然后在执行./create-cluster create 就可以创建一个3主3从的redis集群。如果报错NOT Empty,则执行./create-cluster fix进行修复即可。脚本名称:create-cluster,内容如下:

#!/bin/bash

# Settings
PORT=6999
TIMEOUT=2000
NODES=6
REPLICAS=1
IP=172.16.20.17
EXEC=/usr/local/bin/redis-server
REDISCLI=/usr/local/bin/redis-cli
REDISTRIB=/opt/rediscluster/redis-3.2.6/src/redis-trib.rb
# You may want to put the above config parameters into config.sh in order to
# override the defaults without modifying this script.

if [ -a config.sh ]
then
    source "config.sh"
fi

# Computed vars
ENDPORT=$((PORT+NODES))

if [ "$1" == "start" ]
then
    while [ $((PORT < ENDPORT)) != "0" ]; do
        PORT=$((PORT+1))
        echo "Starting $PORT"
        $EXEC --bind 0.0.0.0 --port $PORT --cluster-enabled yes --cluster-config-file nodes-${PORT}.conf --cluster-node-timeout $TIMEOUT --appendonly yes --appendfilename appendonly-${PORT}.aof --dbfilename dump-${PORT}.rdb --logfile ${PORT}.log --daemonize yes
    done
    exit 0
fi

if [ "$1" == "create" ]
then
    HOSTS=""
    while [ $((PORT < ENDPORT)) != "0" ]; do
        PORT=$((PORT+1))
        HOSTS="$HOSTS $IP:$PORT"
    done
        echo $HOSTS
    echo "$REDISTRIB create --replicas $REPLICAS $HOSTS"
    $REDISTRIB create --replicas $REPLICAS $HOSTS
    exit 0
fi

if [ "$1" == "stop" ]
then
    while [ $((PORT < ENDPORT)) != "0" ]; do
        PORT=$((PORT+1))
        echo "Stopping $PORT"
        $REDISCLI -p $PORT shutdown nosave
    done
    exit 0
fi

if [ "$1" == "watch" ]
then
    PORT=$((PORT+1))
    while [ 1 ]; do
        clear
        date
        $REDISCLI -p $PORT cluster nodes | head -30
        sleep 1
    done
    exit 0
fi

if [ "$1" == "fix" ]
then
   $REDISTRIB fix $IP:$((PORT+1))
   exit 0
fi

  
if [ "$1" == "tail" ]
then
    INSTANCE=$2
    PORT=$((PORT+INSTANCE))
    tail -f ${PORT}.log
    exit 0
fi

if [ "$1" == "call" ]
then
    while [ $((PORT < ENDPORT)) != "0" ]; do
        PORT=$((PORT+1))
        $REDISCLI -p $PORT $2 $3 $4 $5 $6 $7 $8 $9
    done
    exit 0
fi

if [ "$1" == "clean" ]
then
    rm -rf *.log
    rm -rf appendonly*.aof
    rm -rf dump*.rdb
    rm -rf nodes*.conf
    exit 0
fi

echo "Usage: $0 [start|create|stop|watch|tail|clean]"
echo "start       -- Launch Redis Cluster instances."
echo "create      -- Create a cluster using redis-trib create."
echo "fix        -- Fix the cluster when it throw the exception of not empty"
echo "stop        -- Stop Redis Cluster instances."
echo "watch       -- Show CLUSTER NODES output (first 30 lines) of first node."
echo "tail <id>   -- Run tail -f of instance at base port + ID."
echo "clean       -- Remove all instances data, logs, configs."

3. 在php中使用redis cluster 集群

前言前面2篇详细讲解了redis集群的搭建、它的基础命令的实用方法。这一篇说下php中如何实用redis集群。目前我们用到的 php 的 redis 扩展 主要有2个,第一个是最常用的 phpredi...
  • yangyi2083334
  • yangyi2083334
  • 2015年12月23日 10:23
  • 692

Oracle管理及常用基础脚本

引用 :http://blog.csdn.net/lcj8/article/details/2514903 1 性能监控 1. 检测数据库中的事件和等待          SE...
  • lmy4710
  • lmy4710
  • 2014年08月25日 16:01
  • 686

Nginx运维管理脚本

#!/bin/sh # 编译安装管理Nginx App=nginx AppName=Nginx AppBase=/App AppDir=$AppBase/$App AppProg=$AppDir/sb...
  • dongsong1117
  • dongsong1117
  • 2015年04月30日 10:27
  • 817

RedisCluster心得

1、RedisCluster将整个redis集群分为多个不同区间的数据槽位。 2、在一个集群内各服务器所拥有的槽位可以自由调整。 3、可以自由增加和删除节点信息,可以在线迁移缓存数据 4、Red...
  • qq892618896
  • qq892618896
  • 2017年09月21日 10:40
  • 104

java redisCluster

一:redisson和 redisCluster性能对比 组件 操作 数量 耗时(ms) jediscluster hset 100000 213959 jedis...
  • baiducheng
  • baiducheng
  • 2017年09月09日 17:42
  • 68

浏览器的用户脚本管理工具

个人博客: http://demi-panda.com Posted 2013-01-14  |  暂无评论  |  By 熊猫人 用户脚本  互联网  firefox  chrome...
  • a280606790
  • a280606790
  • 2013年01月15日 09:23
  • 1348

redis-py-cluster详述

前文讲了redis3.0引入cluster,怎么能少cluster对应的python client包呢? 1.start pip install redis-py-cluster >>> fro...
  • secretx
  • secretx
  • 2016年08月16日 16:23
  • 2906

Redis Learning

应用场景:redis 适用于小而热的数据 Redis应用场景 Redis作者谈Redis应用场景我们在应用redis的场景是 缓存将收到的post报文缓存下,然后批量插入redshift git...
  • Alan_happy
  • Alan_happy
  • 2017年08月01日 09:14
  • 93

数据库日常管理常用sql脚本

 / 目录: ###########查询类########### 关于session: kill session和kill -9 ...
  • wish503
  • wish503
  • 2016年11月29日 22:43
  • 642

springboot + redis集群实现session共享

springboot + redis集群实现session共享
  • qq_32143169
  • qq_32143169
  • 2017年10月09日 15:47
  • 178
收藏助手
不良信息举报
您举报文章:RedisCluster管理脚本
举报原因:
原因补充:

(最多只允许输入30个字)