redis集群部署及常用的操作命令_01

简单说下自己测试搭建简单的redis集群的大体步骤:

1.首先你的有6个redis(官方说最少6个,3master,3slave),可以先在一台机器上搭建,搭建到多台上应该只需要改变启动命令即可(可能需要一些ssh无密钥什么的,只是猜测)

在网上随便可以找到的配置多个redis,(总体有两种方式,一种是虚拟的,貌似走的都是一个redis,一种是将配置好的redis复制成六份,配置相应的端口等,我选择的后者显得更真实一些)

 

然后把他们全部打开,可以写一个脚本,或者一个一个打开,作为一个新世纪的年轻人,我当然选择一个一个打开它们......

复制代码
[root@localhost ~]# ps -ef | grep redis
root      3427     1  0 7月17 ?       00:02:59 src/redis-server *:6379
root      3454     1  0 7月17 ?       00:06:09 src/redis-server *:7001 [cluster]
root      3460     1  0 7月17 ?       00:06:19 src/redis-server *:7002 [cluster]
root      3467     1  0 7月17 ?       00:05:59 src/redis-server *:7003 [cluster]
root      3473     1  0 7月17 ?       00:05:59 src/redis-server *:7004 [cluster]
root      3477     1  0 7月17 ?       00:05:57 src/redis-server *:7005 [cluster]
root      5867     1  0 12:02 ?       00:00:06 src/redis-server *:7000 [cluster]
root      5938  5913  0 13:17 pts/1    00:00:00 grep --color=auto redis
复制代码

2.将6个独立redis设置为集群,so easy 一句话搞定。其中 --replicas 参数是将6台redis分别分配了主从关系(master挂掉slave可以顶替,但是还没有具体深入研究)

./redis-trib.rb create --replicas 1 127.0.0.1:7000 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

在开启过程中可能会遇到很多问题,各种奇怪的报错,那就要安装ruby和gem的一些东东,搞不明白是什么,反正就是依赖吧~ ,只能说按照这个来会绕开很多坑。

# yum install ruby-devel.x86_64# wget http://rubygems.global.ssl.fastly.net/gems/redis-3.2.1.gem
# gem install -l ./redis-3.2.1.gem

执行这些代码之后再去执行上面建立集群的命令,如果成功的话,会看到下面的样子:

复制代码
>>> Creating cluster  
Connecting to node 127.0.0.1:7000: OK  
Connecting to node 127.0.0.1:7001: OK  
Connecting to node 127.0.0.1:7002: OK  
Connecting to node 127.0.0.1:7003: OK  
Connecting to node 127.0.0.1:7004: OK  
Connecting to node 127.0.0.1:7005: OK  
>>> Performing hash slots allocation on 6 nodes...  
Using 3 masters:  
127.0.0.1:7000  
127.0.0.1:7001  
127.0.0.1:7002  
Adding replica 127.0.0.1:7003 to 127.0.0.1:7000  
Adding replica 127.0.0.1:7004 to 127.0.0.1:7001  
Adding replica 127.0.0.1:7005 to 127.0.0.1:7002  
M: ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a 127.0.0.1:7000  slots:0-5460 (5461 slots) master  
M: d3058a19483d7be5c30c042779e56130f6ebf074 127.0.0.1:7001  slots:5461-10922 (5462 slots) master  
M: 5814305e71552ab45c44b9b8233681a63c3a57b1 127.0.0.1:7002  slots:10923-16383 (5461 slots) master  
S: e50676757acbe7c6a21e8abf4eda26ababb08285 127.0.0.1:7003  replicates ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a  
S: ab307ba26d6dabe8edb2f2a7287be6f01aa46d88 127.0.0.1:7004  replicates d3058a19483d7be5c30c042779e56130f6ebf074  
S: 11174332eb6ad40c0327750536fa776d706caf85 127.0.0.1:7005  replicates 5814305e71552ab45c44b9b8233681a63c3a57b1  
Can I set the above configuration? (type 'yes' to accept): yes  
>>> Nodes configuration updated  
>>> Assign a different config epoch to each node  
>>> Sending CLUSTER MEET messages to join the cluster  
Waiting for the cluster to join...  
>>> Performing Cluster Check (using node 127.0.0.1:7000)  
M: ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a 127.0.0.1:7000  slots:0-5460 (5461 slots) master  
M: d3058a19483d7be5c30c042779e56130f6ebf074 127.0.0.1:7001  slots:5461-10922 (5462 slots) master  
M: 5814305e71552ab45c44b9b8233681a63c3a57b1 127.0.0.1:7002  slots:10923-16383 (5461 slots) master  
M: e50676757acbe7c6a21e8abf4eda26ababb08285 127.0.0.1:7003  slots: (0 slots) master  replicates ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a  
M: ab307ba26d6dabe8edb2f2a7287be6f01aa46d88 127.0.0.1:7004  slots: (0 slots) master  replicates d3058a19483d7be5c30c042779e56130f6ebf074  
M: 11174332eb6ad40c0327750536fa776d706caf85 127.0.0.1:7005  slots: (0 slots) master  replicates 5814305e71552ab45c44b9b8233681a63c3a57b1  
<span style="color:#009900;">[OK] All nodes agree about slots configuration.</span>  
>>> Check for open slots...  
>>> Check slots coverage...  
<span style="color:#009900;">[OK] All 16384 slots covered.</span></span>  
复制代码

3.测试集群。

可以用下面的命令查看集群的状态,从下面可以看出有4个master,2个slave~~~,这个是由于我太年轻kill了7000的redis又加入了进来,原先他的slave 7003 也变成了master顶替了他。

复制代码
[root@localhost src]# ./redis-trib.rb check 127.0.0.1:7000
Connecting to node 127.0.0.1:7000: OK
Connecting to node 127.0.0.1:7005: OK
Connecting to node 127.0.0.1:7003: OK
Connecting to node 127.0.0.1:7002: OK
Connecting to node 127.0.0.1:7001: OK
Connecting to node 127.0.0.1:7004: OK
>>> Performing Cluster Check (using node 127.0.0.1:7000)
M: 4eb95ab689288dbb3ebf7ed380a0593ec9daa878 127.0.0.1:7000slots: (0 slots) master0 additional replica(s)
S: 11174332eb6ad40c0327750536fa776d706caf85 127.0.0.1:7005slots: (0 slots) slavereplicates 5814305e71552ab45c44b9b8233681a63c3a57b1
M: e50676757acbe7c6a21e8abf4eda26ababb08285 127.0.0.1:7003slots:0-5460 (5461 slots) master0 additional replica(s)
M: 5814305e71552ab45c44b9b8233681a63c3a57b1 127.0.0.1:7002slots:10923-16383 (5461 slots) master1 additional replica(s)
M: d3058a19483d7be5c30c042779e56130f6ebf074 127.0.0.1:7001slots:5461-10922 (5462 slots) master1 additional replica(s)
S: ab307ba26d6dabe8edb2f2a7287be6f01aa46d88 127.0.0.1:7004slots: (0 slots) slavereplicates d3058a19483d7be5c30c042779e56130f6ebf074
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
复制代码

可以进入redis中玩一玩:查了一下使用redis-cli命令的时候应该加上 -c ,意思是在集群模式下,否则你会以一种独立的redis进入,然后各种moved报错。

看着存储位置跳来跳去,貌似简单的集群也就搭建完成了。

复制代码
[root@localhost src]# ./redis-cli -c -p 7000
127.0.0.1:7000> set qiang weikang
-> Redirected to slot [1357] located at 127.0.0.1:7003
OK
127.0.0.1:7003> set qiang qiang 
OK
127.0.0.1:7003> set weikang qiang
-> Redirected to slot [12142] located at 127.0.0.1:7002
OK
127.0.0.1:7002> get qiang
-> Redirected to slot [1357] located at 127.0.0.1:7003
"qiang"
127.0.0.1:7003> get weikang
-> Redirected to slot [12142] located at 127.0.0.1:7002
"qiang"
复制代码

转载于:https://www.cnblogs.com/lvcisco/p/10309513.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/264925.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ubuntu网络环境搭建

参考&#xff1a;https://www.bilibili.com/video/BV1n541197rk?spm_id_from333.999.0.0 目录开发板网线直连电脑网口&#xff0c;电脑WIFI上网有的公司保密性强&#xff0c;可能要找网络管理员协助 开发板网线直连电脑网口&#xff0c;电脑WIFI上网 开发板一定要上电并连接到…

高级 IO(非阻塞、多路复用、异步、存储映射、文件锁)

目录非阻塞I/O阻塞I/O 与非阻塞I/O 读文件阻塞I/O 的优点与缺点使用非阻塞I/O实现并发读取I/O 多路复用何为I/O多路复用select()函数poll()函数总结非阻塞I/O 关于“阻塞”一词前面已经给大家多次提到&#xff0c;阻塞其实就是进入了休眠状态&#xff0c;交出了CPU 控制权。前…

程序员---我的读书列表

2019独角兽企业重金招聘Python工程师标准>>> 1、JAVA核心技术 2、knuth《The Art of program》四卷&#xff0c;辅导书《基本数学》 转载于:https://my.oschina.net/muyexia/blog/225376

用SHA1或MD5 算法加密数据(示例:对用户身份验证的简单实现)

(一).功能 用哈希算法: SHA1或MD5 实现用户账号和密码验证. 数据库存储实现原理是: 用户账号直接存储在数据库中&#xff0c;密码经过加密后再存储到数据库中. 当用户登录时&#xff0c;密码要经过加密后再与数据库中的实际存储密码比较&#xff0c;确定是否合法用户…

https网络编程——HTTP协议的简介、HTTP报文结构和代理、HTTP加速解析方法(哈希加速、协议状态机)

参考&#xff1a;HTTP协议的简介及其工作原理等 地址&#xff1a;https://qingmu.blog.csdn.net/article/details/108046553?spm1001.2014.3001.5502 目录HTTP协议的简介及其工作原理1、HTTP简介1.1、什么是超文本&#xff08;HyperText&#xff09;?1.2、什么是URL&#xff…

c# 2.0 Factory的实现

用C#的范型建立一个Factory模式的模板: publicstructFactoryConverter<A, B>{ public static implicit operator A(FactoryConverter<A, B> conv) { return Activator.CreateInstance<A>(); } public static implici…

https网络编程——openssl安装(两个软链接库libssl、libcrypto)、openssl命令行方式实现CA和证书、介绍SSH

参考&#xff1a;openssl安装方式&#xff08;Ubuntu下&#xff09; 地址&#xff1a;https://qingmu.blog.csdn.net/article/details/115454254?spm1001.2014.3001.5502 目录官方网站1、解压2、编译安装3、生成软连接(两个库)4、测试这是B站openssl视频教程&#xff1a;https…

[spring boot] 01 环境搭建 - 配置java和mvn环境

主要内容&#xff1a; 一、IntelliJ IDEA 安装 二、maven 安装 三、设置IDEA和mvn的关系 一、IntelliJ IDEA 安装 1.1. 下载编辑器&#xff1a;前往下载 (Ultimate和Community都是可以的&#xff0c;我一般下载前一个) 1.2. 注册码记得搜索 二、maven 安装 2.1. 下载mvn&#x…

https网络编程——HTTPS简介以及SSL协议详解

参考;HTTPS简介以及SSL协议详解 地址&#xff1a;https://qingmu.blog.csdn.net/article/details/108209248?spm1001.2014.3001.5502 目录1.HTTPS简介2.SSL协议介绍2.1、SSL协议的功能2.2、SSL协议在协议栈的位置2.3、SSL协议组成2.3.1、纪录协议的功能2.3.2、SSL记录协议的示…

D3---01基础的柱状图制作(转)

---文章转自 http://d3.decembercafe.org/index.html &#xff0c;Created by 十二月咖啡馆。 一个完整的柱形图包含三部分&#xff1a;矩形、文字、坐标轴。 首先要布置一个大小合适的 SVG 画布&#xff1a; 添加 SVG 画布 //画布大小 var width 400; var height 400;//在…

https网络编程——对称加密、非对称加密、单项加密的简单介绍

参考&#xff1a;对称加密、非对称加密、单项加密的简单介绍 地址&#xff1a;https://qingmu.blog.csdn.net/article/details/108213426?spm1001.2014.3001.5502 目录1、对称加密1.1、什么是对称加密&#xff1f;1.2、对称加密的优缺点是什么&#xff1f;1.3、常见的对称加密…

dnn中个性化服务的使用

1.什么是profiles(个性化服务)Profiles是系统面向用户提供的灵活性的个体信息的容器&#xff0c;一个用户的Profile可以使以下一种或多种的集合&#xff1a; &#xff08;1&#xff09; 简单的字符串或其他基础类型 &#xff08;2&#xff09; 一个序列化的实体 &#xff08;3&…

洛谷P1073 Tarjan + 拓扑排序 // 构造分层图

https://www.luogu.org/problemnew/show/P1073 C国有 n n个大城市和 mm 条道路&#xff0c;每条道路连接这 nn个城市中的某两个城市。任意两个城市之间最多只有一条道路直接相连。这 mm 条道路中有一部分为单向通行的道路&#xff0c;一部分为双向通行的道路&#xff0c;双向通…

https网络编程——SSL的加密和解密过程

参考&#xff1a;SSL的加密和解密过程 地址&#xff1a;https://qingmu.blog.csdn.net/article/details/108214105?spm1001.2014.3001.5502 目录现在的加密/解密技术主要有三种&#xff1a;对称加密&#xff0c;非对称加密&#xff0c;和单向加密加密解密的流程图现在的加密/解…

IIS网站的权限设置问题

2019独角兽企业重金招聘Python工程师标准>>> IIS中的权限与NTFS权限设置的区别&#xff1a; 当浏览器访问被IIS禁止的页面时&#xff0c;返回404错误页面 但浏览器访问被NTFS禁止的文件时&#xff0c;提示用户登录界面 转载于:https://my.oschina.net/changeme/blog…

关于.Net2.0下配置架构的使用

上次用到配置文件,就花了一些时间研究了一下.Net2.0下的配置文件架构,当时感觉确实很强大,完善,但看的有些头晕.迷迷糊糊把实现了要求,就没有再深入研究.最近,想在配置文件里实现一个复杂的配置,多层次嵌套的配置文件,再把.Net中的配置文档研究了一下&#xff0c;经过这两次的研…

煲仔

湖南的煲仔似乎在我毕业工作的那年侵占了大街小巷&#xff0c;满街的煲仔店向外热滋滋的喷着香味&#xff0c;便宜又好味。那几年在外的觅食&#xff0c;除了常德津市牛肉米饭外&#xff0c;煲仔似乎是我唯一的选择。将米放入煲内&#xff0c;加水在火上煮至半熟&#xff0c;再…

https网络编程——中继(负载均衡)工作原理

参考&#xff1a;中继&#xff08;负载均衡&#xff09;工作原理 地址&#xff1a;https://qingmu.blog.csdn.net/article/details/108217055?spm1001.2014.3001.5502 中继&#xff08;负载均衡&#xff09;工作原理 在我们当前社会&#xff0c;比如我们上某宝&#xff0c;某…

全套支付宝系统架构(内部架构图)【收藏】

据说这是对支付宝系统体系最全最强解析&#xff0c;推荐收藏学习&#xff01; 转载于:https://www.cnblogs.com/SH-xuliang/p/10340745.html

iOS学习之iOS沙盒(sandbox)机制和文件操作之NSFileManager

2019独角兽企业重金招聘Python工程师标准>>> 1、在Documents里创建目录 创建一个叫test的目录,先找到Documents的目录&#xff0c; [cpp] view plain copy NSArray *paths NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); …