redis集群部署及常用的操作命令(上)
简单说下自己测试搭建简单的redis集群的大体步骤:
1.首先你的有6个redis(官方说最少6个,3master,3slave),可以先在一台机器上搭建,搭建到多台上应该只需要改变启动命令即可(可能需要一些ssh无密钥什么的,只是猜测)
在网上随便可以找到的配置多个redis,(总体有两种方式,一种是虚拟的,貌似走的都是一个redis,一种是将配置好的redis复制成六份,配置相应的端口等,我选择的后者显得更真实一些)
然后把他们全部打开,可以写一个脚本,或者一个一个打开,作为一个新世纪的年轻人,我当然选择一个一个打开它们......
[root@localhost ~]# ps -ef | grep redis
root 7月17 ? :: src/redis-server *:
root 7月17 ? :: src/redis-server *: [cluster]
root 7月17 ? :: src/redis-server *: [cluster]
root 7月17 ? :: src/redis-server *: [cluster]
root 7月17 ? :: src/redis-server *: [cluster]
root 7月17 ? :: src/redis-server *: [cluster]
root : ? ::06 src/redis-server *: [cluster]
root : pts/ :: grep --color=auto redis
2.将6个独立redis设置为集群,so easy 一句话搞定。其中 --replicas 参数是将6台redis分别分配了主从关系(master挂掉slave可以顶替,但是还没有具体深入研究)
./redis-trib.rb create --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:
在开启过程中可能会遇到很多问题,各种奇怪的报错,那就要安装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..gem
执行这些代码之后再去执行上面建立集群的命令,如果成功的话,会看到下面的样子:
>>> Creating cluster
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 hash slots allocation on nodes...
Using masters:
127.0.0.1:
127.0.0.1:
127.0.0.1:
Adding replica 127.0.0.1: to 127.0.0.1:
Adding replica 127.0.0.1: to 127.0.0.1:
Adding replica 127.0.0.1: to 127.0.0.1:
M: ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a 127.0.0.1:
slots:- ( slots) master
M: d3058a19483d7be5c30c042779e56130f6ebf074 127.0.0.1:
slots:- ( slots) master
M: 5814305e71552ab45c44b9b8233681a63c3a57b1 127.0.0.1:
slots:- ( slots) master
S: e50676757acbe7c6a21e8abf4eda26ababb08285 127.0.0.1:
replicates ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a
S: ab307ba26d6dabe8edb2f2a7287be6f01aa46d88 127.0.0.1:
replicates d3058a19483d7be5c30c042779e56130f6ebf074
S: 11174332eb6ad40c0327750536fa776d706caf85 127.0.0.1:
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:)
M: ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a 127.0.0.1:
slots:- ( slots) master
M: d3058a19483d7be5c30c042779e56130f6ebf074 127.0.0.1:
slots:- ( slots) master
M: 5814305e71552ab45c44b9b8233681a63c3a57b1 127.0.0.1:
slots:- ( slots) master
M: e50676757acbe7c6a21e8abf4eda26ababb08285 127.0.0.1:
slots: ( slots) master
replicates ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a
M: ab307ba26d6dabe8edb2f2a7287be6f01aa46d88 127.0.0.1:
slots: ( slots) master
replicates d3058a19483d7be5c30c042779e56130f6ebf074
M: 11174332eb6ad40c0327750536fa776d706caf85 127.0.0.1:
slots: ( 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 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:
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: 4eb95ab689288dbb3ebf7ed380a0593ec9daa878 127.0.0.1:
slots: ( slots) master
additional replica(s)
S: 11174332eb6ad40c0327750536fa776d706caf85 127.0.0.1:
slots: ( slots) slave
replicates 5814305e71552ab45c44b9b8233681a63c3a57b1
M: e50676757acbe7c6a21e8abf4eda26ababb08285 127.0.0.1:
slots:- ( slots) master
additional replica(s)
M: 5814305e71552ab45c44b9b8233681a63c3a57b1 127.0.0.1:
slots:- ( slots) master
additional replica(s)
M: d3058a19483d7be5c30c042779e56130f6ebf074 127.0.0.1:
slots:- ( slots) master
additional replica(s)
S: ab307ba26d6dabe8edb2f2a7287be6f01aa46d88 127.0.0.1:
slots: ( slots) slave
replicates d3058a19483d7be5c30c042779e56130f6ebf074
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All slots covered.
可以进入redis中玩一玩:查了一下使用redis-cli命令的时候应该加上 -c ,意思是在集群模式下,否则你会以一种独立的redis进入,然后各种moved报错。
看着存储位置跳来跳去,貌似简单的集群也就搭建完成了。
[root@localhost src]# ./redis-cli -c -p
127.0.0.1:> set qiang weikang
-> Redirected to slot [] located at 127.0.0.1:
OK
127.0.0.1:> set qiang qiang
OK
127.0.0.1:> set weikang qiang
-> Redirected to slot [] located at 127.0.0.1:
OK
127.0.0.1:> get qiang
-> Redirected to slot [] located at 127.0.0.1:
"qiang"
127.0.0.1:> get weikang
-> Redirected to slot [] located at 127.0.0.1:
"qiang"
4.遗留的一些问题:
(1)搭建的集群连接上客户端后,所有的redis只有db0可用,不知道是什么原因。(难道是互相之间只连接了db0吗?)
(2)增删改节点还有待继续研究,不能只是单纯的写命令就可以了,要理解在什么场景下应该做如何的处理。
(3)集群管理工具在redis 3.0之后自己出了一个叫做redis-sentinel的,这个需要着重研究。
只有在深入理解的集群的意义和所配置的每个参数的含义之后,才能使用到生产环境中,以上只是个入门,学习redis集群才只是刚刚开始~~
redis集群部署及常用的操作命令(上)的更多相关文章
- redis集群部署及常用的操作命令_01
简单说下自己测试搭建简单的redis集群的大体步骤: 1.首先你的有6个redis(官方说最少6个,3master,3slave),可以先在一台机器上搭建,搭建到多台上应该只需要改变启动命令即可(可能 ...
- redis集群部署及常用的操作命令(下)
搭建好集群之后,为了扩容需要再加入一个节点.那就再复制一个7006,改为相应的redis.conf(复制了改个port就好,如果复制的redis之前属于集群,需要把关联的node.conf之类的去掉) ...
- 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 ...
随机推荐
- JVM调优总结(这个总结得比较全面)
堆大小设置 JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制:系统的可用虚拟内存限制:系统的可用物理内存限制.32位系统下,一般限制在1.5G~2G:64为操 ...
- mysql命令之二:查看mysql版本的四种方法
1:在终端下:mysql -V. 以下是代码片段: [shengting@login ~]$ mysql -V mysql Ver 14.7 Distrib 4.1.10a, for redhat-l ...
- javascript数组的申明方式以及常用方法
数组的定义: 方法1. var mycars=new Array()mycars[0]="Saab"mycars[1]="Volvo"mycars[2]=&qu ...
- css:层叠样式表-网页布局基础
css:层叠样式表:一.写法分类: 1.内联(行内,写在标签里面,以属性的形式表现,属性名是style) 例:<table style="background-color: aqua& ...
- kafka 高可靠
1.集群高可靠 ①搭建kafka集群(略) ②重点配置项(每个broker配置相同,只有broker.id不一样) broker.id=1 当前机器在集群中的唯一标识,和zookeeper的m ...
- Oracle查看和修改连接数
1.查询数据库当前进程的连接数: select count(*) from v$process; 2.查看数据库当前会话的连接数: elect count(*) from v$sessio ...
- maven将手动下载的jar包安装到本地仓库
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://mave ...
- canvas旋转文本
canvas旋转文本 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...
- 使用json格式去call外部系统
1. 使用postman去call post方式 body填入对应的json请求 格式选json 2. 使用java 代码去call import java.io.BufferedReader; im ...
- UNITY 模型与动画优化选项
1,RIG: Optimze Game Objects,[默认是没勾选的] 效果:将骨骼层级从模型中移除,放到动画控制器中,这样性能提高明显.实测中发现原来瞬间加载5个场景角色有点延迟,采用此选项后流 ...