单个机器部署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测试功 ...
随机推荐
- 2018-2-13-安装-aria2
title author date CreateTime categories 安装 aria2 lindexi 2018-2-13 17:23:3 +0800 2018-2-13 17:23:3 + ...
- WiFi基础知识
自从只需少量的话费就可以将笔记本.平板电脑连接到互联网,WiFi已成为我们熟知的网络,并无处不在.Wi-Fi对于一些物联网应用十分有用,比如楼宇自动化.内部能源管理.WiFi的重要性对于我们的日常生活 ...
- nexus私服仓库搭建以及项目引用
第一步:使用ubunto下载安装nexus 并打开登录进入到nexus管理页面,默认账号为 admin 密码在 admin.password 中,首次登录会让你重新修改密码 第二步 配置自己本地 ...
- MHA-Atlas-MySQL高可用(下)
MHA-Atlas-MySQL高可用(下) 链接:https://pan.baidu.com/s/17Av92KQnJ81Gc0EmxSO7gA 提取码:a8mq 复制这段内容后打开百度网盘手机App ...
- goto和函数调用
goto: 函数调用: 作用域 label在函数内定义,所以函数内 跳转操作 无条件 调用时先保存现场,复制实际参数,然后才是跳转 生存期 由于不是左值,它没有生存期,仅在编译期有意义. ...
- JAVA设计模式之迭代器设计模式
一.迭代器模式简介 Iterator模式也叫迭代模式,是行为模式之一,它把对容器中包含的内部对象的访问委让给外部类,使用Iterator(遍历)按顺序进行遍历访问的设计模式. 二.迭代器模式的角色与职 ...
- leetcode-161周赛-5248-统计【优美子数组】
题目描述: 自己的提交:超时: class Solution: def numberOfSubarrays(self, nums, k: int) -> int: dp = [0]* (len( ...
- SQL SELECT TOP, LIMIT, ROWNUM
SQL SELECT TOP, LIMIT, ROWNUM SQL SELECT TOP 子句 SELECT TOP 子句用于指定要返回的记录数量. SELECT TOP子句在包含数千条记录的大型表上 ...
- 【LeetCode 17】电话号码的字母组合
题目链接 [题解] 用回溯法搞一下. 一搞就有~ 注意输入空串的时候别返回那个空串.. [代码] class Solution { public: string dic[10]; vector< ...
- RFS自动化测试工具安装与使用总结
转载:http://blog.csdn.net/a5650892/article/details/77826021 一,调试1,在调试时,总时提示“无法打开浏览器”解决办法:1,把浏览器的代理关闭2, ...