Redis集群搭建完整攻略

1.Redis安装和配置

# 先安装编译环境
yum groupinstall "Development tools"

cd /home/packages

# 下载redis
curl -O http://download.redis.io/releases/redis-5.0.0.tar.gz

# 解压
tar -zxf redis-*.tar.gz

# 将解压的源码目录放到自己的应用目录
mv -f redis-5.0.0 /usr/local/redis

cd /usr/local/redis

# 编译安装, 编译问题可以自行搜索
./configure
make
make install

# 测试是否安装成功, 如果出现版本号说明已经安装成功
redis-cli -v

2.修改配置

vi redis.conf

bind 192.168.1.100

port 6379

daemonize yes # 是否需要以守护进程启动(如果为no, 启动后在前台, ctrl-c退出进程, 可以使用nohub的方式转入后台)

pidfile /var/run/redis_6379.pid # 可以自行选择目录, 但是确保已经建立好指定的目录再启动服务, 否则启动报错

logfile "/var/redis/log/6379.log" # 日志目录, 确保存在否则启动报错

dir /var/redis/data # 数据存放目录(RDB和AOF共用), 确保存在否则启动报错

dbfilename 6379.rdb # rdb数据持久化文件

appendonly yes # 打开aof

appendfilename "6379.aof" # aof数据持久化文件

cluster-enabled yes # 集群配置, 开启时单实例机无法执行数据操作(get | set 等)

cluster-config-file nodes-6379.conf # 自动生成, 保存到上面指定的data目录
其他配置保持默认即可.

启动服务推荐使用redis/utils/redis_init_script

为启动脚本建立软连接方便使用

ln -s $PWD/utils/redis_init_script /usr/bin/redis

# 这个脚本默认读取的配置文件位置为 /etc/redis/$PORT.conf, 所以先在这个建立位置一个redis.conf的软连接,文件名为端口号
mkdir /etc/redis
ln -s $PWD/redis.conf /etc/redis/6379.conf

# 使用方式如下
redis [start | stop]

# 要查看服务是否已经成功开启, 可根据端口查看或使用客户端连接一次
netstat -npl | grep 6379 # 部分系统版本需要安装net-tools

以上步骤顺利完成后, 就可以开始集群配置了, redis集群至少要求3主3从, 所以至少需要6个单实例服务, 可以通过单机6个配置的方式, 或多个宿主机的方式配置.

3.集群配置

单机多配置

只需要拷贝多份配置文件和启动脚本, 将这两个文件中的端口对应的值替换为不同的端口

特别需要注意的是单机配置多个redis时, 时刻记得-->改端口,改端口,改端口<-- 不能两个服务重复使用同一个端口

mkdir ../redis2

cp redis.conf ../redis2/

cp utils/redis_init_script ../redis2

cd ../redis2

sed -i s/6379/7379/ redis.conf

sed -i s/6379/7379 redis_init_script

ln -s $PWD/redis.conf /etc/redis/7379.conf

./redis_init_script start

# 查看服务是否成功启动, 如果没有出现进程, 查看日志排查问题(一般是指定的文件夹不存在)
netstat -npl | grep 7379

# 如法炮制其他4个吧, 配置好后6个实例都启动起来

多机配置

每个主机上运行一个redis其实没什么好写的,就是步骤1 和 2, 安装完成后开启服务就好了

4.安装ruby环境

redis对ruby的版本有要求, 目前CentOS7的仓库版本还是很低, 需要到官网下载安装

# 如果当前系统已经附带了一个低版本的ruby 需要先卸载
yum erase ruby
# 如果是之前自己使用yum安装的, 完整回滚安装操作(remove或者erase不会卸载依赖型)
yum history list ruby
# 结果如下
#    ID | 命令行                   | 日期和时间       | 操作           | 变更数
#-------------------------------------------------------------------------------
#    25 | install ruby -y          | 2018-10-04 16:14 | Install        |    8

# 拿到ID后回滚之前的操作
yum history undo 25

cd /home/packages

curl -O https://cache.ruby-lang.org/pub/ruby/2.5/ruby-2.5.3.tar.gz

tar -zxf ruby-2.5.3.tar.gz

cd ruby-2.5.3

./configure --disable-install-doc # 我是没安装文档, 如果需要的可以去掉后边的参数

make && make install

# 检查是否已经成功安装ruby
ruby -v

# 安装gem
cd ..

curl -O https://rubygems.org/rubygems/rubygems-2.7.7.zip

unzip rubygems-2.7.7.zip

cd rubygems-2.7.7

ruby setup.rb

gem -v

# 为ruby安装redis组件, 这一步可能比较慢
gem install redis

至此, ruby环境也装好了, 可以开始建集群了

5. 创建集群

redis-trib create --replicas 1 192.168.1.100:6379 192.168.1.100:7379 192.168.1.100:8379 192.168.1.100:9379 192.168.1.100:10379 192.168.1.100:11379

# 如果一切正常, 输出应该是长这样
# >>> Creating cluster
# >>> Performing hash slots allocation on 6 nodes...
# Using 3 masters:
# 192.168.25.110:6379
# 192.168.25.120:6379
# 192.168.25.210:6379
# Adding replica 192.168.25.120:7379 to 192.168.25.110:6379
# Adding replica 192.168.25.110:7379 to 192.168.25.120:6379
# Adding replica 192.168.25.220:6379 to 192.168.25.210:6379
# M: ed9332ea65afb70c615936bb69f3c0081e9ab472 192.168.25.110:6379
#    slots:0-5460 (5461 slots) master
# S: 281dc2be56b2dbe5c726c656b2b4b0017d396394 192.168.25.110:7379
#    replicates acae299367e8f5a742980ac6aa089baf5eb6b5a2
# M: acae299367e8f5a742980ac6aa089baf5eb6b5a2 192.168.25.120:6379
#    slots:5461-10922 (5462 slots) master
# S: caf5a016f022b6f33cd3317ef7dd643ce800131a 192.168.25.120:7379
#    replicates ed9332ea65afb70c615936bb69f3c0081e9ab472
# M: a0c41601d30159940c2bcccce08c3fad2406dfd0 192.168.25.210:6379
#    slots:10923-16383 (5461 slots) master
# S: 387442c1fbdad2a2f2c6f17506c3ebc4c01d55bc 192.168.25.220:6379
#    replicates a0c41601d30159940c2bcccce08c3fad2406dfd0
# 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 192.168.25.110:6379)
# M: ed9332ea65afb70c615936bb69f3c0081e9ab472 192.168.25.110:6379
#    slots:0-5460 (5461 slots) master
#    1 additional replica(s)
# M: a0c41601d30159940c2bcccce08c3fad2406dfd0 192.168.25.210:6379
#    slots:10923-16383 (5461 slots) master
#    1 additional replica(s)
# M: acae299367e8f5a742980ac6aa089baf5eb6b5a2 192.168.25.120:6379
#    slots:5461-10922 (5462 slots) master
#    1 additional replica(s)
# S: 387442c1fbdad2a2f2c6f17506c3ebc4c01d55bc 192.168.25.220:6379
#    slots: (0 slots) slave
#    replicates a0c41601d30159940c2bcccce08c3fad2406dfd0
# S: 281dc2be56b2dbe5c726c656b2b4b0017d396394 192.168.25.110:7379
#    slots: (0 slots) slave
#    replicates acae299367e8f5a742980ac6aa089baf5eb6b5a2
# S: caf5a016f022b6f33cd3317ef7dd643ce800131a 192.168.25.120:7379
#    slots: (0 slots) slave
#    replicates ed9332ea65afb70c615936bb69f3c0081e9ab472
# [OK] All nodes agree about slots configuration.
# >>> Check for open slots...
# >>> Check slots coverage...
# [OK] All 16384 slots covered.

6.问题解决

#### 6.1 问题1

创建集群出现如下错误

rubygems/core_ext/kernel_require.rb:59:in `require': cannot load such file -- redis (LoadError)

这种还没开始执行创建就已经脚本错误的情况, 一般是没为ruby安装redis组件引起的, 参考 第4步

#### 6.2 问题2

创建集群的时候出现如下错误

Can I set the above configuration? (type 'yes' to accept): yes
/usr/local/lib/ruby/gems/2.4.0/gems/redis-4.0.2/lib/redis/client.rb:119:in `call': ERR Slot 0 is already busy (Redis::CommandError)

也就是提示槽xxx繁忙的时候, 将建立集群的每个节点清除数据并重置

[root@leader1 redis]# redis-cli -h leader1 6379
leader1:6379> flushall
OK
leader1:6379> cluster reset
OK
leader1:6379> quit

# 别的节点执行一样的操作

7.使用集群

使用客户端连接时, 添加一个参数 -c

[root@leader1 redis2]# redis-cli -h 192.168.1.100 -p 6379 -c
# 测试集群
leader1:6379> set name sealin
-> Redirected to slot [5798] located at 192.168.25.120:6379
OK
192.168.25.120:6379>
# 可以发现操作已经被重定向到了集群中的另一个节点
# 切换一个主机获取数据试试
[root@leader1 redis2]# redis-cli -h follower1 -c
follower1:6379> get name
-> Redirected to slot [5798] located at 192.168.25.120:6379
"sealin"
192.168.25.120:6379>
# 同样的转向到了该节点获取数据

# 查看集群信息
leader1:6379> cluster info
cluster_state:ok
cluster_slots_assigned:16384
cluster_slots_ok:16384
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:6
cluster_size:3
cluster_current_epoch:6
cluster_my_epoch:1
cluster_stats_messages_ping_sent:18037
cluster_stats_messages_pong_sent:15989
cluster_stats_messages_fail_sent:4
cluster_stats_messages_sent:34030
cluster_stats_messages_ping_received:15984
cluster_stats_messages_pong_received:15745
cluster_stats_messages_meet_received:5
cluster_stats_messages_fail_received:3
cluster_stats_messages_received:31737

# 查看节点信息
leader1:6379> cluster nodes
a0c41601d30159940c2bcccce08c3fad2406dfd0 192.168.25.210:6379@16379 master - 0 1539966870000 3 connected 10923-16383
acae299367e8f5a742980ac6aa089baf5eb6b5a2 192.168.25.120:6379@16379 master - 0 1539966869719 2 connected 5461-10922
387442c1fbdad2a2f2c6f17506c3ebc4c01d55bc 192.168.25.220:6379@16379 slave a0c41601d30159940c2bcccce08c3fad2406dfd0 0 1539966871737 4 connected
281dc2be56b2dbe5c726c656b2b4b0017d396394 192.168.25.110:7379@17379 slave acae299367e8f5a742980ac6aa089baf5eb6b5a2 0 1539966868710 5 connected
caf5a016f022b6f33cd3317ef7dd643ce800131a 192.168.25.120:7379@17379 slave ed9332ea65afb70c615936bb69f3c0081e9ab472 0 1539966870729 4 connected
ed9332ea65afb70c615936bb69f3c0081e9ab472 192.168.25.110:6379@16379 myself,master - 0 1539966863000 1 connected 0-5460

整个搭建流程到此结束了, 祝君好运.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,045评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,114评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,120评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,902评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,828评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,132评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,590评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,258评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,408评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,335评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,385评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,068评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,660评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,747评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,967评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,406评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,970评论 2 341

推荐阅读更多精彩内容