linux下redis4.0.2集群部署(利用原生命令)
一、部署架构如下
每台服务器准备2个节点,一主一从,主节点为另外两台其中一台的主,从节点为另外两台其中一台的从。
二、准备6个节点配置文件
在172.28.18.75上操作
cd /etc/redis
vim redis-25701.conf
内容如下
bind 172.28.18.75
port 25701
masterauth "Zaq1xsw@"
requirepass "Zaq1xsw@"
protected-mode yes
daemonize yes
dir "/etc/redis"
pidfile "/var/run/redis_25701.pid"
loglevel notice
logfile "redis-25701.log"
dbfilename "dump-25701.rdb" cluster-enabled yes
cluster-node-timeout 15000
cluster-config-file node-25701.conf
cluster-require-full-coverage no
替换端口号,并生成一个从节点配置文件
sed 's/25701/25702/g' redis-25701.conf > redis-25702.conf
复制这两个配置文件到172.28.18.103和172.28.18.104对应的目录下
scp -P25601 redis-25701.conf root@172.28.18.103:/etc/redis/
scp -P25601 redis-25702.conf root@172.28.18.103:/etc/redis/
scp -P25601 redis-25701.conf root@172.28.18.104:/etc/redis/
scp -P25601 redis-25702.conf root@172.28.18.104:/etc/redis/
三、启动6个节点
redis-server redis-25701.conf
查看redis-25701.log
集群模式运行
打开node-25701.conf文件,里面有如下内容
表示自己的nodeid,并且是一个master,发现自己,
启动从节点:
redis-server redis-25702.conf
按照以上操作,启动另外两台服务器的4个节点
启动完毕,可以使用redis-cli来查看集群信息:
redis-cli -h 172.28.18.75 -p 25701 -a password cluster nodes
查看集群配置文件内容
redis-cli -h 172.28.18.75 -p 25701 -a password cluster info
当前集群状态是失败的,分配的槽为0
四、执行节点之间的meet操作,使相互之间可以通信感知对方
在172.28.18.75上执行
将25701节点和25702节点之间通信,返回OK,成功,此时我们查看25701的节点信息,已经感知到了25702节点信息
同样查看25702,也感知到了25701
继续执行meet操作,使172.28.18.75的25701和另外两台服务器的25701和25702通信
redis-cli -h 172.28.18.75 -p 25701 -a password cluster meet 172.28.18.103 25701
redis-cli -h 172.28.18.75 -p 25701 -a password cluster meet 172.28.18.103 25702
redis-cli -h 172.28.18.75 -p 25701 -a password cluster meet 172.28.18.104 25701
redis-cli -h 172.28.18.75 -p 25701 -a password cluster meet 172.28.18.104 25702
此时,所有节点都感知到了对方,总共6个节点
握手操作成功完成,目前配置显示所有节点都是master,所以接下来需要设置主从
五、设置主从节点
172.28.18.75 25701(主)--》172.28.18.103 25702(从)
172.28.18.103 25701(主)--》172.28.18.104 25702(从)
172.28.18.104 25701(主)--》172.28.18.75 25702(从)
1、172.28.18.75 25701(主)--》172.28.18.103 25702(从)
在从节点172.28.18.103上操作
redis-cli -h 172.28.18.103 -p 25702 -a password cluster replicate 5f5939a7b9f6c1290173b7d326b076ee0736a268
25702:从节点端口
5f5939a7b9f6c1290173b7d326b076ee0736a268:主节点nodeid,可通过 redis-cli 的cluster nodes 来查询
返回ok,查询cluster nodes,25702已经变成172.28.18.75 25701的从节点
再查询172.28.18.75 25701节点信息,103的25702成为了他的从节点
再按照以上操作设置另外两台主从
在172.28.18.104上执行
将104 25702变成103 25701的从节点
在172.28.18.75上执行
将75 25702变成104 25701的从节点
此时,查看75 25701集群节点信息
3主3从设置完毕
六、为主节点分配槽slot
3主:将16384个槽分为3份,0到5461的数据分到75 25701端口,将5462到10922的数据分到103 25701端口,10923到16383的数据分到104 25701端口
在172.28.18.75上编写脚本
vim add_slots.sh
#!/bin/bash start=$ #定义一个起始变量
end=$ #定义一个结束变量 for slot in `seq $start $end` #利用for循环来重复执行命令,在slot中
do
echo "slot:$slot"
redis-cli -h 172.28.18.75 -p 25701 -a password cluster addslots $slot
done
执行脚本:
chmod +x add_slots.sh
./add_slots.sh 0 5461
完毕后,查看节点信息
成功分配5462个槽
在另外两台服务器也分配剩余的槽
./add_slots.sh 5462 10922
./add_slots.sh 10923 16383
查看槽分配结果
redis-cli -h 172.28.18.75 -p 25701 -a password cluster slots
5461个槽分配到172.28.18.75 25701上,并且它的从节点为172.28.18.103 25702
到此,分配槽操作完毕。
七、测试结果
连接172.28.18.75 25701,注意一定要加"-c"参数,否则如果数据没有分配到当前节点则不会自动连接其他集群的节点。
redis-cli -c -h 172.28.18.75 -p 25701 -a password
返回OK,并且数据被分配到了104 25701节点的槽里。并且连接也自动变为104的25701,此时get
返回数据。集群已经正常工作。
此时,停掉172.28.18.75 25701主节点,172.28.18.103 25702将晋升为主节点
查看172.28.18.103 25702节点信息
此时自己成为master,而172.28.18.75 25701则显示失败状态,此时把172.28.18.75 25701节点启动
此时自己成为从节点,再查看172.28.18.103 25702节点信息,172.28.18.75 25701,已经成为salve。
至此,redis原生安装集群设置完毕。
linux下redis4.0.2集群部署(利用原生命令)的更多相关文章
- linux下redis4.0.2集群部署(利用Ruby脚本命令)
一.原生命令方式和Ruby脚本方式区别 利用Ruby脚本部署和用原生命令部署,节点准备的步骤都是一样的,节点启动后的握手,以及主从.槽分配,利用Ruby脚本一步就能完成,利用原生命令需要一步一步地执行 ...
- linux下redis4.0.2安装与部署
一.redis的介绍 Redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcache类似,但很大程度补偿了Memcache的不足,它支持存储的value类型相对更 ...
- Linux下搭建Lotus Domino集群
Linux下搭建Lotus Domino 集群 本文内容是Linux平台下Lotus Domino服务器部署案例(http://chenguang.blog.51cto.com/350944/1334 ...
- Linux下MySQL/MariaDB Galera集群搭建过程【转】
MariaDB介绍 MariaDB是开源社区维护的一个MySQL分支,由MySQL的创始人Michael Widenius主导开发,采用GPL授权许可证. MariaDB的目的是完全兼容MySQL,包 ...
- Linux下Hadoop2.7.3集群环境的搭建
Linux下Hadoop2.7.3集群环境的搭建 本文旨在提供最基本的,可以用于在生产环境进行Hadoop.HDFS分布式环境的搭建,对自己是个总结和整理,也能方便新人学习使用. 基础环境 JDK的安 ...
- hbase-2.0.4集群部署
hbase-2.0.4集群部署 1. 集群节点规划: rzx1 HMaster,HRegionServer rzx2 HRegionServer rzx3 HRegionServer 前提:搭建好ha ...
- redis4.0.1集群安装部署
安装环境 序号 项目 值 1 OS版本 Red Hat Enterprise Linux Server release 7.1 (Maipo) 2 内核版本 3.10.0-229.el7.x86_64 ...
- Redis-4.0.11集群配置
版本:redis-3.0.5 redis-3.2.0 redis-3.2.9 redis-4.0.11 参考:http://redis.io/topics/cluster-tutorial. 集群 ...
- redis-5.0.5 集群部署
之前写过一套基于redis-4.0.6版本的测试集群部署 https://www.cnblogs.com/mrice/p/10730309.html 最近生产环境需要部署一套redis-5.0.5版本 ...
随机推荐
- 记一次ssh配置的锅
我们在使用git来管理代码的时候不可避免的要用到ssh密匙,这个密匙怎么配置的百度上很多. 我这边是使用sourcetree来配合管理代码的,但是我ssh配置好了以后无论是克隆代码还是推送代码都提示我 ...
- java-Calendar类
1.Calendar类的概述和获取日期的方法 * A:Calendar类的概述 * Calendar 类是一个抽象类,它为特定瞬间与一组诸如 YEAR.MONTH.DAY_OF_MONTH.HOUR ...
- github二次认证接收短信的问题
这两天登陆github都被提示说我账号的密码已经被归类,提醒我修改密码. 改密码的时候发现GitHub有个二次认证的功能,分别是app和sms短信认证.app这里就不讲了,我们讲一下github的短信 ...
- 算法图解 (Aditya Bhargava 著)
第1章 算法简介第2章 选择排序第3章 递归第4章 快速排序第5章 散列表第6章 广度优先搜索第7章 狄克斯特拉算法第8章 贪婪算法第9章 动态规划第10章 K最近邻算法第11章 接下来如何做 第1章 ...
- javaScript 中的私有,共有,特权属性和方法
function constructor () { var private_v; // 私有属性 var private_f = function () { // 私有方法 // code }; th ...
- win10+vs2015编译caffe的cpu debug版本、部署matcaffe
一.编译caffe 1.安装python-3.5.2-amd64.exe https://www.python.org/ftp/python/3.5.2/python-3.5.2-amd64.exe ...
- Springboot 允许跨域访问
服务提供段Application.java中添加如下代码: @Beanpublic CorsFilter corsFilter() { UrlBasedCorsConfigurationSource ...
- 将string转为同名类名,方法名。(c#反射)
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace stri ...
- C# 代码小技巧
一 .自动属性. 1.vs下输入prop,Tab键就出现了. 2.有了自动属性,我们不用再额外为一个类的每个公共属性定义一个私有字段(实际上没多大用处的字段), 但是通过反射还是可以看到对应的私有 ...
- DataSource - 常用数据库连接池 (DBCP、c3p0、Druid) 配置说明
1. 引言 1.1 定义 数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出.对数据库连接的管理能显著影响到整个应用程序的伸缩性和健壮性,影响到程序的性能指标.数据库 ...