redis集群部署及常用的操作命令(下)
搭建好集群之后,为了扩容需要再加入一个节点。那就再复制一个7006,改为相应的redis.conf(复制了改个port就好,如果复制的redis之前属于集群,需要把关联的node.conf之类的去掉)
[root@localhost ]# vim redis.conf
[root@localhost ]# src/redis-server redis.conf
[root@localhost ]# ps -ef | grep redis
root : pts/ :: src/redis-server *:
root : ? :: src/redis-server *: [cluster]
root : ? :: src/redis-server *: [cluster]
root : ? :: src/redis-server *: [cluster]
root : ? :: src/redis-server *: [cluster]
root : ? :: src/redis-server *: [cluster]
root : ? :: src/redis-server *: [cluster]
root : ? :: src/redis-server *: [cluster]
(1)添加节点
很简单的一句命令: 前面是地址是新加入的一台redis,后面是属于之前集群的任意一台。
[root@localhost ]# src/redis-trib.rb add-node 127.0.0.1: 127.0.0.1:
>>> Adding node 127.0.0.1: to cluster 127.0.0.1:
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
>>> Performing Cluster Check (using node 127.0.0.1:)
M: 0bbc46d087d7256fb7b71ca35871446e29926afa 127.0.0.1:
slots:- ( slots) master
additional replica(s)
S: ec376f305428afde24aa363919a863f01908c140 127.0.0.1:
slots: ( slots) slave
replicates 0bbc46d087d7256fb7b71ca35871446e29926afa
M: 0b521aa8664b2e51475470230f3a975bdd4d1909 127.0.0.1:
slots:- ( slots) master
additional replica(s)
S: d1a7c6485909a119a1c276f3972b8ae3f93e52d7 127.0.0.1:
slots: ( slots) slave
replicates 0b521aa8664b2e51475470230f3a975bdd4d1909
M: 9b7b98c4bf2517e4f172a895b5728d13bef62952 127.0.0.1:
slots:- ( slots) master
additional replica(s)
S: ee95130f0aed20c62881df8070d7690c4608a7cc 127.0.0.1:
slots: ( slots) slave
replicates 9b7b98c4bf2517e4f172a895b5728d13bef62952
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All slots covered.
Connecting to node 127.0.0.1:: OK
>>> Send CLUSTER MEET to node 127.0.0.1: to make it join the cluster.
[OK] New node added correctly.
可以任意进入一台机器来查看是否添加了新的节点,会发现刚刚添加的节点并没有托管任何的哈希槽,原因是里面还木有数据了。增加从节点只需要加上--slave参数
[root@localhost ]# src/redis-cli -c -p
127.0.0.1:> cluster nodes
0bbc46d087d7256fb7b71ca35871446e29926afa 127.0.0.1: myself,master - connected -
32cc36d5deead5d8eb3208120d6f38358c9b6a55 127.0.0.1: master - connected
ec376f305428afde24aa363919a863f01908c140 127.0.0.1: slave 0bbc46d087d7256fb7b71ca35871446e29926afa connected
0b521aa8664b2e51475470230f3a975bdd4d1909 127.0.0.1: master - connected -
d1a7c6485909a119a1c276f3972b8ae3f93e52d7 127.0.0.1: slave 0b521aa8664b2e51475470230f3a975bdd4d1909 connected
9b7b98c4bf2517e4f172a895b5728d13bef62952 127.0.0.1: master - connected -
ee95130f0aed20c62881df8070d7690c4608a7cc 127.0.0.1: slave 9b7b98c4bf2517e4f172a895b5728d13bef62952 connected
(2)删除节点
删除节点之前首先要保证节点中没有数据,如果有数据需要分片,把数据转移走。后面跟着的id用cluster nodes 就能查看到对应的啦~
删除有数据的我还需要研究研究。。。因为一些很拙计的原因~~, ./redis-trib.rb reshard 127.0.0.1: 这句是转移时讲数据分配到那些哈希槽下的命令。
[root@localhost ]# src/redis-trib.rb del-node 127.0.0.1: 'c8ed852a52863e941a6e63037e018eb2952b776a'
>>> Removing node c8ed852a52863e941a6e63037e018eb2952b776a from cluster 127.0.0.1:
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
Connecting to node 127.0.0.1:: OK
>>> Sending CLUSTER FORGET messages to the cluster...
>>> SHUTDOWN the node.
好的,假装他删的很顺利~~
还有需要补充的之后继续补充......
redis集群部署及常用的操作命令(下)的更多相关文章
- redis集群部署及常用的操作命令(上)
简单说下自己测试搭建简单的redis集群的大体步骤: 1.首先你的有6个redis(官方说最少6个,3master,3slave),可以先在一台机器上搭建,搭建到多台上应该只需要改变启动命令即可(可能 ...
- redis集群部署及常用的操作命令_01
简单说下自己测试搭建简单的redis集群的大体步骤: 1.首先你的有6个redis(官方说最少6个,3master,3slave),可以先在一台机器上搭建,搭建到多台上应该只需要改变启动命令即可(可能 ...
- Redis集群部署与维护
Redis集群部署与维护 目录: 一. 集群架构 二. 集群部署 1. 创建redis-cluster目录 2. 编译redis 3. 编辑redis配置文件 4. 配置redis集群 5. redi ...
- Redis集群部署及命令
一.简介 redis集群是一个无中心的分布式Redis存储架构,可以在多个节点之间进行数据共享,解决了Redis高可用.可扩展等问题. redis集群提供了以下两个好处: 将数据自动切分(split) ...
- Redis集群部署-windows
Redis集群部署-windows 前言 为了能体验一下部署Redis集群是一种怎么样的体验,所一边做一边写了这篇记录. 1.准备 从这里下载windows服务端 https://github.com ...
- Redis集群部署文档(Ubuntu15.10系统)
Redis集群部署文档(Ubuntu15.10系统)(要让集群正常工作至少需要3个主节点,在这里我们要创建6个redis节点,其中三个为主节点,三个为从节点,对应的redis节点的ip和端口对应关系如 ...
- Redis集群部署3.0
我用的Mac的终端 ------------------------- 1.Redis简介 centos(5.4) Redis是一个key-value存储系统.和Memcached类似,但是解决了断 ...
- 二进制redis集群部署
二进制redis集群部署 〇.前言 无聊想学罢了 准备环境: 三台centos7 1C1GB即可 三个路相连的地址 主机 IP 节点-角色-实例(端口) redis1 172.16.106.128 M ...
- Redis 集群部署
一.下载所需软件包 redis wget http://download.redis.io/releases/redis-4.0.6.tar.gz ruby wget https://cache.ru ...
随机推荐
- 解决近期linux下yum更新出现HTTP Error 404 NOT FOUND错误的办法
本文转载自:http://tech.lezi.com/archives/47 最近两天使用yum的163源,出现404错误 [root@localhost yum.repos.d]# yum make ...
- Druid.io系列(一):简介
原文链接: https://blog.csdn.net/njpjsoftdev/article/details/52955676 Druid.io(以下简称Druid)是面向海量数据的.用于实时查询与 ...
- Firefox显示 您的链接不安全 的解决办法
Firefox浏览器,今天突然打开网页的时候提醒,“您的链接不安全”,于是网页怎么刷新都打不开.后来几经查询终于解决,下面告诉大家该如何解决这种情况. 百度经验:jingyan.baidu.com 工 ...
- Nginx加状态监控
安装Nginx时加上 –with-http_stub_status_module 在nginx.conf server location /nginx_status { stub_sta ...
- 防火墙启动失败,提示最后一行出错【COMMIT】
使用 /etc/init.d/iptables save 后 iptables配置文件发生变化 并生成iptables.save vim iptables.save [配置内容则是原来的] s ...
- Vue基础知识之指令和生命周期(一)
优点:轻量易学,灵活. 核心:通过尽可能简单的API来实现响应的数据绑定和组合的视图组件. 1.数据绑定:数据改变,驱动视图的自动更新. 2.视图组件化:把整个网页拆分成一个个区块,每个区块都可以看成 ...
- Julia - 字符串判断函数
isascii() 判断是否是 ascii 码,返回 Bool 值 julia> isascii('a') true julia> isascii('α') false julia> ...
- 1.celery概述
1. 问题抛出 我们在做网站后端程序开发时,会碰到这样的需求:用户需要在我们的网站填写注册信息,我们发给用户一封注册激活邮件到用户邮箱,如果由于各种原因,这封邮件发送所需时间较长,那么客户端将会等待很 ...
- Delegate(代理)异常:该委托必须有一个目标
转自 Delegate(代理)异常:该委托必须有一个目标 在代理调用BeginInvoke(new AsyncCallback(callBack), null);时,会抛这个异常的原因是该代理变量代理 ...
- Android MVP模式简单易懂的介绍方式 (三)
Android MVP模式简单易懂的介绍方式 (一) Android MVP模式简单易懂的介绍方式 (二) Android MVP模式简单易懂的介绍方式 (三) 讲完M和P,接下来就要讲V了.View ...