一、检查机器是否安装gcc、unzip、wget

二、部署模式

#模式1: 将所有主从节点以及sentinel节点部署在同一台机器上

#模式2: 将一个数据节点和一个sentinel节点部署在一台机器上,如master+sentinel1,slave1+sentinel2

#模式3: 将所有节点分开部署

三、一键部署脚本

1、在/root/test/目录下创建目录7001 7002 7003 7004 7005 7006 以及env

##7001~7006目录用来存放redis的配置文件redis.conf,env用来存放生成的公共配置文件redis-env.conf

for ((i=;i<=;i++))
do
mkdir -p /root/test/${i} env
done

2、进入env目录,创建公共配置文件redis-env.conf

cd env

echo -e "port 7001\ncluster-enabled yes\ndir /root/test/7001\ncluster-config-file nodes-7001.conf\npidfile "/root/test//redis-.pid"\nlogfile "/root/test//redis-.log"\nappendonly yes" > "redis-env.conf"

注意:绑定本机IP的配置得加上注释,不然别的IP访问不了你的redis服务;也可以使用本机的内容IP

Redis配置文件之include、network、general 可以参考https://www.jianshu.com/p/51c0ee9317b3

3、拷贝公共配置文件redis-env.con 到7001~7006目录下,并根据端口修改redis-env.conf 传递的端口值以及文件名包含7001的字段

for ((i=;i<=;i++))
do cp /root/test/env/redis.conf /root/test/${i}
sed -i "s/7001/700${i}/g" /root/test/${i}/redis.conf
done

4、检查wget是否已经安装

check_results1=`rpm -qa | grep "wget"`
if [[ $check_results1 =~ "wget" ]]
then
echo "package wget has already installed. "
else
echo "This is going to install package wget"
yum install wget -y
fi

5、下载redis安装包,并解压

#安装redis
wget http://download.redis.io/releases/redis-5.0.5.tar.gz
#解压安装包
tar -zxvf redis-5.0..tar.gz

6、进入解压目录,编译

#编译
cd redis-5.0.
make
#make install

7、启动redis各个节点

(1)方式一:进入redis解压得到的目录,创建脚本 start.sh

cd /root/test/redis-5.0.
vim start.sh
# 内容如下

./src/redis-server /root/test/7001/redis.conf &
./src/redis-server /root/test/7002/redis.conf &
./src/redis-server /root/test/7003/redis.conf &
./src/redis-server /root/test/7004/redis.conf &
./src/redis-server /root/test/7005/redis.conf &
./src/redis-server /root/test/7006/redis.conf &

 

保存退出,并且赋予脚本权限

chmod +x start.sh

检查redis启动是否成功

ps -ef |grep redis

(2)方式二:进入/root/test 目录创建 start.sh 脚本

#启动redis各个节点
for((i=;i<=;i++))
do
cd ${i}
/root/test/redis-5.0./src/redis-server /root/test/${i}/redis.conf &
cd ..
done

保存退出,并且赋予脚本权限

chmod +x start.sh

检查redis启动是否成功

ps -ef |grep redis

8、创建redis集群

./redis-5.0.5/src/redis-cli --cluster create --cluster-replicas  127.0.0.1: 127.0.0.1: 127.0.0.1: 127.0.0.1: 127.0.0.1: 127.0.0.1:

现在高版本的redis-cli已经支持集群了,不再需要安装ruby了。

9、判断 Can I set the above configuration? (type 'yes' to accept): 则输入yes

10、一键关闭redis-server脚本

ps -ef | grep redis-server | grep -v grep | awk '{print $2}' | xargs kill -9

11、删除redis集群

(1)关闭redis-server服务

(2)将各个节点的cluster-config-file nodes-7001.conf 文件删除掉

(3)重新启动redis

(4)创建redis集群

四、整理代码

1、一键部署代码

##1、在/root/test/目录下创建目录7001 7002 7003 7004 7005 7006 以及env
##7001~7006目录用来存放redis的配置文件redis.conf,env用来存放生成的公共配置文件redis-env.conf
for ((i=1;i<=6;i++))
do
mkdir -p /root/test/700${i} /root/test/env
done

##2、进入env目录
cd /root/test/env

echo -e "port 7001\ncluster-enabled yes\ndir /root/test/7001\ncluster-config-file nodes-7001.conf\npidfile "/root/test/7001/redis-7001.pid"\nlogfile "/root/test/7001/redis-7001.log"\nappendonly yes" > "redis-env.conf"

##3、拷贝公共配置文件redis-env.con 到7001~7006目录下,并根据端口修改7001
for ((i=1;i<=6;i++))
do

cp /root/test/env/redis-env.conf /root/test/700${i}/redis.conf
sed -i "s/7001/700${i}/g" /root/test/700${i}/redis.conf
done

##4、下载安装redis

#检查wget
check_results1=`rpm -qa | grep "wget"`
if [[ $check_results1 =~ "wget" ]]
then
echo "package wget has already installed. "
else
echo "This is going to install package wget"
yum install wget -y
fi

cd /root/test
#安装redis
wget http://download.redis.io/releases/redis-5.0.5.tar.gz
#解压安装包
tar -zxvf redis-5.0.5.tar.gz
#编译
cd /root/test/redis-5.0.5
make
#make install

cd /root/test/redis-5.0.5

echo '打印当前路径'

pwd

##5启动redis各个节点
for((i=1;i<=6;i++))
do
./src/redis-server /root/test/700$i/redis.conf &
sleep 1
done

cd /root/test/redis-5.0.5
sleep 1
#创建集群
./src/redis-cli --cluster create --cluster-replicas 1 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006

# 注意创建集群时,需要手动输入yes

2、关闭redis-server 服务,并删除创建的7001~7006 目录下的nodes文件

echo "正在关闭redis-server..."
ps -ef | grep redis-server | grep -v grep | awk '{print $2}' | xargs kill -
ps -ef |grep redis
sleep
echo "正在删除redis的nodes文件..."
for ((i=;i<=;i++))
do
rm -rf /root/test/${i}/nodes-${i}.conf
echo "删除700${i}目录下的nodes文件"
done

单个机器部署redis集群模式(一键部署脚本)的更多相关文章

  1. 5分钟实现用docker搭建Redis集群模式和哨兵模式

    如果让你为开发.测试环境分别搭一套哨兵和集群模式的redis,你最快需要多久,或许你需要一天?2小时?事实是可以更短. 是的,你已经猜到了,用docker部署,真的只需要十几分钟. 一.准备工作 拉取 ...

  2. 7.redis 集群模式的工作原理能说一下么?在集群模式下,redis 的 key 是如何寻址的?分布式寻址都有哪些算法?了解一致性 hash 算法吗?

    作者:中华石杉 面试题 redis 集群模式的工作原理能说一下么?在集群模式下,redis 的 key 是如何寻址的?分布式寻址都有哪些算法?了解一致性 hash 算法吗? 面试官心理分析 在前几年, ...

  3. 突破Java面试-Redis集群模式的原理

    1 面试题 Redis集群模式的工作原理说一下?在集群模式下,key是如何寻址的?寻址都有哪些算法?了解一致性hash吗? 2 考点分析 Redis不断在发展-Redis cluster集群模式,可以 ...

  4. Redis集群模式之分布式集群模式

    前言 Redis集群模式主要有2种: 主从集群 分布式集群. 前者主要是为了高可用或是读写分离,后者为了更好的存储数据,负载均衡. 本文主要讲解主从集群.本章主要讲解后一半部分,Redis集群. 与本 ...

  5. Centos7部署Redis集群

    Redis简介 Redis(Remote Dictionary Server)是完全开源的.遵守BSD协议的.高性能的Key-Value数据库. Redis与其他Key-Value缓存产品有一下三个特 ...

  6. Redis集群命令行部署工具

    使用之前准备工作: 1)配置好与端口无关的公共redis.conf文件,和工具放在同一目录下 2)配置好与端口相关的模板redis-PORT.conf文件,也和工具放在同一目录下(部署时PORT会被替 ...

  7. laravel项目利用twemproxy部署redis集群的完整步骤

    Twemproxy是一个代理服务器,可以通过它减少Memcached或Redis服务器所打开的连接数.下面这篇文章主要给大家介绍了关于laravel项目利用twemproxy部署redis集群的相关资 ...

  8. Redis集群模式配置

    redis集群部署安装: https://blog.csdn.net/huwh_/article/details/79242625 https://www.cnblogs.com/mafly/p/re ...

  9. Centos6.6部署Redis集群

    Centos6.6部署Redis集群 1环境准备 1环境安装redis 1安装ruby 2配置redis主从环境 3部署redis sentinel服务器 5集群使用 13当前集群环境说明 13测试功 ...

随机推荐

  1. 案例-3D旋转木马

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. android studio安装中出现Failed to install Intel HAXM错误的解决方法

    1.问题分析 从下面可以知道安装Intel HAXM失败,请检查haxm_silent_run.log这篇日志. (1)先了解一下什么是Intel HAXM Intel代表的是英特尔,HAXM的全程是 ...

  3. icomoon字体图标引用代码

    1.第一步在样式里声明字体:告诉别人我们自己定义的字体. @font-face{ /*声明字体 引用字体*/ font-family:'icomoon'; src:url('fonts/icomoon ...

  4. Python模块和模块引用(一)

    """ import my_module as mm courses = ['History','Math','Physics','CompSci'] index = m ...

  5. foreach循环的跳出

    由于foreach循环中不像for循环可以直接通过return或break来终止当前循环,不过这里可以借助try...catch...来完成var arr = [1,2,3,4,5,6,7,8,9,1 ...

  6. openFrameworks Download

    { https://openframeworks.cc/zh_cn//download/ } 0.10.1 是最新发布的版本. 这个版本是修改了一些BUG的小版本,与版本 0.10.1100%兼容而且 ...

  7. git——修改已经提交并push后的commit注释

    把代码push到远程后,发现commit的注释居然多了几个错别字,不行,必须改了! 搜索了一些答案之后自己做了一个总结如下: ①修改倒数第次的commit 指令:$ git rebase -i HEA ...

  8. VC 串口通讯基本原理,讲的很是详细

    目 录打开串口............................................................................................. ...

  9. nuxt 2.0采坑计之 (引入静态文件css)

    nuxt 2.0采坑计之静态文件css 外部引入css 全局引用方法为   (在nuxt.config.js配置中在   module.exports = {}  中添加) head: { meta: ...

  10. sqlmap用户手册详解【实用版】

    网上的sqlmap教程很多,但是我自己备忘小笔记都是在我的电脑上存着了,万一我要出去玩的时候,有点忘了,还得再百度翻翻,还不如发到我自己知乎上,忘了立马一看就记着了.虽说我的sqlmap备忘小笔记汇总 ...