我是靠谱客的博主 谨慎芝麻,最近开发中收集的这篇文章主要介绍Mac搭建Redis集群模式,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

Mac搭建Redis集群模式

一、安装 Redis

1.Mac 环境下安装 Redis 是非常简单的,直接执行命令:brew install redis 就可以了(需要安装 homebrew),这也是我比较推荐的方式。通过 homebrew 安装 Redis 之后,Redis 的环境变量、卸载、更新都可以通过简单的命令来完成,也就是说你不再需要考虑管理 Redis 的问题了。

2.安装完成之后,就可以直接在终端执行命令:

  • redis-server:启动 redis 服务器,默认端口 6379
  • redis-cli:启动 redis 客户端

二、配置Redis集群环境

说明:通过 homebrew 安装完成之后,redis 的默认配置文件(redis.conf)的路径位于:/usr/local/etc,环境配置的操作也基本在这个路径下完成。各个步骤的详细说明可以参考文档:Redis 集群这个操作包含了两个步骤:创建 Redis 虚拟节点的目录,并修改虚拟节点的配置文件,下面详细说明。

1.创建Redis虚拟节点目录

在 /usr/local/etc 下创建 cluster 目录,并在 cluster 目录下创建目录:7000、7001、7002、7003、7004、7005。需要执行的命令:
#需要在 /usr/local/etc 路径下
mkdir -p redis/cluster/7000
mkdir -p redis/cluster/7001
mkdir -p redis/cluster/7002
mkdir -p redis/cluster/7003
mkdir -p redis/cluster/7004
mkdir -p redis/cluster/7005

2.修改配置文件

拷贝 Redis 默认的配置文件(/usr/local/etc/redis.conf)到 7000、7001、7002、7003、7004、7005 这6个目录中。修改每一个目录下的配置文件,这里以 7000 为例:

# cp redis.conf redis/cluster/7000/7000.conf
port 7000
# Redis 节点的端口号
cluster-enabled yes
# 实例以集群模式运行
cluster-config-file nodes-7000.conf
# 节点配置文件路径
cluster-node-timeout 5000
# 节点间通信的超时时间
appendonly yes
# 数据持久化

3.启动 Redis,并验证各个节点的状态

在任意目录执行下面的6个命令,即启动6个 Redis 节点:

redis-server /usr/local/etc/redis/cluster/7000/7000.conf &
redis-server /usr/local/etc/redis/cluster/7001/7001.conf &
redis-server /usr/local/etc/redis/cluster/7002/7002.conf &
redis-server /usr/local/etc/redis/cluster/7003/7003.conf &
redis-server /usr/local/etc/redis/cluster/7004/7004.conf &
redis-server /usr/local/etc/redis/cluster/7005/7005.conf &

4.通过命令启动之后,查看当前系统是否存在对应的进程。如果能看到如下类似的结果,则说明启动成功。

 ps -ef |grep redis
119804143 69725
643
0
6:55下午 ttys009
0:01.37 redis-server 127.0.0.1:7000 [cluster]
119804143 69771
643
0
6:56下午 ttys009
0:00.80 redis-server 127.0.0.1:7001 [cluster]
119804143 69809
643
0
6:57下午 ttys009
0:00.11 redis-server 127.0.0.1:7002 [cluster]
119804143 69816
643
0
6:57下午 ttys009
0:00.08 redis-server 127.0.0.1:7003 [cluster]
119804143 69831
643
0
6:57下午 ttys009
0:00.04 redis-server 127.0.0.1:7004 [cluster]
119804143 69851
643
0
6:57下午 ttys009
0:00.03 redis-server 127.0.0.1:7005 [cluster]

5.创建集群(Redis5.0之前的版本要下载ruby,5.0之后版本直接看第六步)

当前系统中已经有了6个正在运行的 Redis 实例,需要使用 Redis 集群命令行工具 redis-trib 来完成集群的创建工作。redis-trib 可以在 redis-trib 下载地址 下载得到。它是一个 Ruby 程序,这个程序通过向实例发送特殊命令来完成创建新集群,检查集群,或者对集群进行重新分片(reshared)等工作。需要安装 Redis 的 Ruby 模块。执行以下命令:

brew update
brew install ruby
sudo gem install redis

在 redis-trib.rb 文件所在目录执行命令:

原来的5.0 以下版本 需要借助ruby
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

6.redis版本高的问题. redis5已经不支持 edis-trib.rb 来创建集群. 应改为

# 无需指定哪个节点为 master,哪个节点为 slave,因为 redis 内部算法已经帮我们实现了
# 使用 --cluster-replicas 1 创建集群,即每个 master 带一个 slave
redis-cli --cluster create
--cluster-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,然后输入yes

redis-cli --cluster create
--cluster-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
Performing hash slots allocation on 6 nodes...
Master[0] -> Slots 0 - 5460
Master[1] -> Slots 5461 - 10922
Master[2] -> Slots 10923 - 16383
Adding replica 127.0.0.1:7004 to 127.0.0.1:7000
Adding replica 127.0.0.1:7005 to 127.0.0.1:7001
Adding replica 127.0.0.1:7003 to 127.0.0.1:7002
Trying to optimize slaves allocation for anti-affinity
[WARNING] Some slaves are in the same host as their master
M: ef5a97c40258974a05d4eff0c5f19b9d76829904 127.0.0.1:7000
slots:[0-5460] (5461 slots) master
M: eedda195caca5724ab5857298f008852bd6688ac 127.0.0.1:7001
slots:[5461-10922] (5462 slots) master
M: a6137b34eb7c1f61727da52253970a1d79f7d8ff 127.0.0.1:7002
slots:[10923-16383] (5461 slots) master
S: d60224e699f1df776f67f9f6373801a7bc76d49b 127.0.0.1:7003
replicates a6137b34eb7c1f61727da52253970a1d79f7d8ff
S: ee52fa9811e21ec51d791262885dd2daa6113e1e 127.0.0.1:7004
replicates ef5a97c40258974a05d4eff0c5f19b9d76829904
S: c9a1473816ab0457ccb5b92d163a2fda7594be48 127.0.0.1:7005
replicates eedda195caca5724ab5857298f008852bd6688ac
Can I set the above configuration? (type 'yes' to accept): yes

出现以下信息代表配置成功 三个Master 三个Slave(三主三丛)

>>> Performing Cluster Check (using node 127.0.0.1:7000)
M: ef5a97c40258974a05d4eff0c5f19b9d76829904 127.0.0.1:7000
slots:[0-5460] (5461 slots) master
1 additional replica(s)
S: ee52fa9811e21ec51d791262885dd2daa6113e1e 127.0.0.1:7004
slots: (0 slots) slave
replicates ef5a97c40258974a05d4eff0c5f19b9d76829904
S: d60224e699f1df776f67f9f6373801a7bc76d49b 127.0.0.1:7003
slots: (0 slots) slave
replicates a6137b34eb7c1f61727da52253970a1d79f7d8ff
M: a6137b34eb7c1f61727da52253970a1d79f7d8ff 127.0.0.1:7002
slots:[10923-16383] (5461 slots) master
1 additional replica(s)
M: eedda195caca5724ab5857298f008852bd6688ac 127.0.0.1:7001
slots:[5461-10922] (5462 slots) master
1 additional replica(s)
S: c9a1473816ab0457ccb5b92d163a2fda7594be48 127.0.0.1:7005
slots: (0 slots) slave
replicates eedda195caca5724ab5857298f008852bd6688ac
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.

7.验证集群可用性

登录客户端,执行操作

# 登录任意一个节点,执行 set、get 等命令
redis-cli -c -p 7000
127.0.0.1:7000> set name lichengxin
-> Redirected to slot [5798] located at 127.0.0.1:7001
OK
127.0.0.1:7001> get name
"lichengxin"

到此,Mac 环境下 Redis 集群的搭建就完成了。
有什么问题欢迎在评论区提问或私信我,会及时回复和更改

最后

以上就是谨慎芝麻为你收集整理的Mac搭建Redis集群模式的全部内容,希望文章能够帮你解决Mac搭建Redis集群模式所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(294)

评论列表共有 0 条评论

立即
投稿
返回
顶部