Redis 官网集群步骤

文章目录

[隐藏]

  • 1. 创建目录
  • 2. 修改配置文件
  • 3. 运行实例
  • 4. 创建集群
  • 5. 简单测试
1. 创建目录

要让集群正常运作至少需要三个主节点, 不过在刚开始试用集群功能时, 强烈建议使用六个节点: 其中三个为主节点, 而其余三个则是各个主节点的从节点
创建一个新目录 redis,并在其中创建六个以端口号为名字的子目录,每个子目录都是一个 redis

mkdir redis  cd redis  mkdir 7000 7001 7002 7003 7004 7005  
2. 修改配置文件

分别进入每个子目录,修改 redis.conf 中如下的配置项

port 7000  cluster-enabled yes  cluster-config-file nodes.conf  cluster-node-timeout 5000  appendonly yes  

其中端口号 port 分别为 7000-7005

3. 运行实例

接着,从 https://github.com/antirez/redis 页面的 unstable 分支中下载最新代码,然后编译出可执行文件放在 redis 文件夹中。(其实从我们的任一子目录里面编译后在 src 文件夹里拿出来也可以)通过如下命令分别创建出 6 个实例

cd 7000  ../redis-server ./redis.conf  
4. 创建集群

可以使用 src 目录中的 redis-trib 程序来创建集群,首先需要安装 redis gem 才能运行 redis-trib

gem install redis  

然后创建集群

./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  

然后终端会列出集群的情况,并礼貌性的问你这样创建可以吗,当然是输入 yes

>>> Creating cluster  >>> 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: 968f13cefb4f895cec739794835fcd160bde22af 127.0.0.1:7000     slots:0-5460 (5461 slots) master  M: 3c088766a36ed8ccd7bef5e6e2fbe75c48bc10c0 127.0.0.1:7001     slots:5461-10922 (5462 slots) master  M: 433145fbee24fa60a3e7194b9b8056b02f375023 127.0.0.1:7002     slots:10923-16383 (5461 slots) master  S: d29b5ce6e4ea9a33a9044d4211ba37aafa5198f8 127.0.0.1:7003     replicates 968f13cefb4f895cec739794835fcd160bde22af  S: ba9052a112e11e757a563ce6ed89adde463c7ec5 127.0.0.1:7004     replicates 3c088766a36ed8ccd7bef5e6e2fbe75c48bc10c0  S: 130bfe6c6e1b8d31ed1e030ae7c41902be268a1f 127.0.0.1:7005     replicates 433145fbee24fa60a3e7194b9b8056b02f375023  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: 968f13cefb4f895cec739794835fcd160bde22af 127.0.0.1:7000     slots:0-5460 (5461 slots) master     1 additional replica(s)  M: 433145fbee24fa60a3e7194b9b8056b02f375023 127.0.0.1:7002     slots:10923-16383 (5461 slots) master     1 additional replica(s)  M: 3c088766a36ed8ccd7bef5e6e2fbe75c48bc10c0 127.0.0.1:7001     slots:5461-10922 (5462 slots) master     1 additional replica(s)  S: ba9052a112e11e757a563ce6ed89adde463c7ec5 127.0.0.1:7004     slots: (0 slots) slave     replicates 3c088766a36ed8ccd7bef5e6e2fbe75c48bc10c0  S: d29b5ce6e4ea9a33a9044d4211ba37aafa5198f8 127.0.0.1:7003     slots: (0 slots) slave     replicates 968f13cefb4f895cec739794835fcd160bde22af  S: 130bfe6c6e1b8d31ed1e030ae7c41902be268a1f 127.0.0.1:7005     slots: (0 slots) slave     replicates 433145fbee24fa60a3e7194b9b8056b02f375023  [OK] All nodes agree about slots configuration.  >>> Check for open slots...  >>> Check slots coverage...  [OK] All 16384 slots covered.  

到此集群就创建成功了。

但很明显这是个伪集群,如果条件允许的话建议使用 6 台机器来创建集群,只需修改相应的地址和端口,并在防火墙开放该端口就行。

5. 简单测试

使用 redis-cli 进行简单的命令测试

$ redis-cli -c -p 7000  redis 127.0.0.1:7000> set foo bar  -> Redirected to slot [12182] located at 127.0.0.1:7002  OK  redis 127.0.0.1:7002> set hello world  -> Redirected to slot [866] located at 127.0.0.1:7000  OK  redis 127.0.0.1:7000> get foo  -> Redirected to slot [12182] located at 127.0.0.1:7002  "bar"  redis 127.0.0.1:7000> get hello  -> Redirected to slot [866] located at 127.0.0.1:7000  "world"  

原文出处:desirelll -> http://desirelll.com/2017/10/25/Redis%20%E5%AE%98%E7%BD%91%E9%9B%86%E7%BE%A4%E6%AD%A5%E9%AA%A4/

本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如果侵犯你的利益,请发送邮箱到 [email protected],我们会很快的为您处理。