单个机器部署redis集群模式(一键部署脚本)
一、检查机器是否安装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集群模式(一键部署脚本)的更多相关文章
- 5分钟实现用docker搭建Redis集群模式和哨兵模式
如果让你为开发.测试环境分别搭一套哨兵和集群模式的redis,你最快需要多久,或许你需要一天?2小时?事实是可以更短. 是的,你已经猜到了,用docker部署,真的只需要十几分钟. 一.准备工作 拉取 ...
- 7.redis 集群模式的工作原理能说一下么?在集群模式下,redis 的 key 是如何寻址的?分布式寻址都有哪些算法?了解一致性 hash 算法吗?
作者:中华石杉 面试题 redis 集群模式的工作原理能说一下么?在集群模式下,redis 的 key 是如何寻址的?分布式寻址都有哪些算法?了解一致性 hash 算法吗? 面试官心理分析 在前几年, ...
- 突破Java面试-Redis集群模式的原理
1 面试题 Redis集群模式的工作原理说一下?在集群模式下,key是如何寻址的?寻址都有哪些算法?了解一致性hash吗? 2 考点分析 Redis不断在发展-Redis cluster集群模式,可以 ...
- Redis集群模式之分布式集群模式
前言 Redis集群模式主要有2种: 主从集群 分布式集群. 前者主要是为了高可用或是读写分离,后者为了更好的存储数据,负载均衡. 本文主要讲解主从集群.本章主要讲解后一半部分,Redis集群. 与本 ...
- Centos7部署Redis集群
Redis简介 Redis(Remote Dictionary Server)是完全开源的.遵守BSD协议的.高性能的Key-Value数据库. Redis与其他Key-Value缓存产品有一下三个特 ...
- Redis集群命令行部署工具
使用之前准备工作: 1)配置好与端口无关的公共redis.conf文件,和工具放在同一目录下 2)配置好与端口相关的模板redis-PORT.conf文件,也和工具放在同一目录下(部署时PORT会被替 ...
- laravel项目利用twemproxy部署redis集群的完整步骤
Twemproxy是一个代理服务器,可以通过它减少Memcached或Redis服务器所打开的连接数.下面这篇文章主要给大家介绍了关于laravel项目利用twemproxy部署redis集群的相关资 ...
- Redis集群模式配置
redis集群部署安装: https://blog.csdn.net/huwh_/article/details/79242625 https://www.cnblogs.com/mafly/p/re ...
- Centos6.6部署Redis集群
Centos6.6部署Redis集群 1环境准备 1环境安装redis 1安装ruby 2配置redis主从环境 3部署redis sentinel服务器 5集群使用 13当前集群环境说明 13测试功 ...
随机推荐
- NOPI Excel 数据导入到数据库
/// <summary> /// 上传excel文件 并将文件数据导入到数据库 /// </summary> /// <param name="file&qu ...
- teb-安装
源码:https://github.com/rst-tu-dortmund/teb_local_planner.git 以husky为例子: 1.在gazebo里面配置好机器人底盘的环境 roslau ...
- _declspec(dllexport)和.def(转)
节选自:windows下编译和使用动态库dll http://blog.eonew.cn/archives/865 Microsoft 在 Visual C++ 的 16 位编译器版本中引入了 __e ...
- mongodb 可视化工具
mongodb是用命令行输入的,有些人可能不太习惯,我自己找了下mongodb的一些可视化工具,发现了一款adminmongo很好用,这里介绍给你们用一下. github地址:https://gith ...
- 72.Properties(配置文件)
Properties(配置文件):主要用于存储配置文件到硬盘上面和读取配置文件 public class Properties extends Hashtable<Object,Object&g ...
- Jedis连接池的使用(转)
http://www.cnblogs.com/linjiqin/archive/2013/06/14/3135248.html 所需jar:jedis-2.1.0.jar和commons-pool-1 ...
- css自适应问题
1. 图片自适应 <img src="app-logo.png" srcset="app-logo.png 175w,app-logo-double.png 365 ...
- MySql中创建存储过程
MySQL 存储过程是从 MySQL 5.0 开始增加的新功能.存储过程的优点有一箩筐.不过最主要的还是执行效率和SQL 代码封装.特别是 SQL 代码封装功能,如果没有存储过程,在外部程序访问数据库 ...
- 海外版本Google登录
海外版本: 1.安裝谷歌安裝器:手机浏览器搜索“谷歌安装器”,安装酷安的好一些,地址: https://www.coolapk.com/apk/com.goplaycn.googleinstall 2 ...
- HTML5自定义属性的设置与获取
<div id="box" aaa="bbb" data-info="hello"></div> <body& ...