redis集群搭建

一.资源准备

  1. 准备三台机器(能连外网,能相互ping通)

172.29.2.10 172.29.2.11 172.29.2.12

  1. 分别安装依赖包,关闭防火墙
[root@localhost src]# systemctl disable firewalld
[root@localhost src]# systemctl stop firewalld
[root@localhost redis]# yum install gcc-c++
[root@localhost redis]# yum install ruby
[root@localhost redis]# yum install rubygems

二.每台机器先安装单机redis

[root@localhost redis]# cd /usr/local
[root@localhost redis]# wget http://download.redis.io/releases/redis-4.0.10.tar.gz
[root@localhost redis]# tar -zxvf redis-4.0.10.tar.gz
[root@localhost redis]# mv redis-4.0.10 redis
[root@localhost redis]# cd redis
[root@localhost redis]# make MALLOC=libc
[root@localhost redis]# make install

注意上面操作是3台机器都安装
安装完成,这时候会在/usr/local/bin/目录下看到redis-server、redis-cli等可执行脚本,进入看一下,如果没有,就要去解压目录复制进去了。

[root@localhost redis]# cd /usr/local/bin/
[root@localhost bin]# ll
总用量 11536
-rwxr-xr-x. 1 root root  353680 1月   4 09:21 redis-benchmark
-rwxr-xr-x. 1 root root 3643680 1月   4 09:21 redis-check-aof
-rwxr-xr-x. 1 root root 3643680 1月   4 09:21 redis-check-rdb
-rwxr-xr-x. 1 root root  519880 1月   4 09:21 redis-cli
lrwxrwxrwx. 1 root root      12 1月   4 09:21 redis-sentinel -> redis-server
-rwxr-xr-x. 1 root root 3643680 1月   4 09:21 redis-server

三.构建redis集群

  1. 建立集群文件夹和配置(三台机器都要配置)
# redis 占用端口,对应自己目录
port 7000
bind 0.0.0.0
daemonize yes   
##如果配置yes则开启集群功能,此redis实例作为集群的一个节点,否则,它是一个普通的单一的redis实例。
cluster-enabled yes  

#它是集群节点自动维护的文件,主要用于记录集群中有哪些节点、#他们的状态以及一些持久化参数等,方便在重启时恢复这些状态。通常是在收到请求之后这个文件就会被更新。
cluster-config-file nodes_7000.conf                                                        


#这是集群中的节点能够失联的最大时间,超过这个时间,该节点就会被认为故障。如果主节点超过这个时间还#是不可达,则用它的从节点将启动故障迁移,升级成主节点。注意,任何一个节点在这个>时间之内如果还是没
#有连上大部分的主节点,则此节点将停止接收任何请求。一般设置为15秒即可。
cluster-node-timeout 15000   
#开启aof持久化模式,每次写操作请求都追加到appendonly.aof文件中
appendonly yes  
#每次有写操作的时候都同步
appendfsync always  
#redis服务日志 
logfile /usr/local/app/redis-cluster/7000/redis.log
#pidfile文件对应7000,7001,7002
pidfile /var/run/redis_7000.pid

分别建立的redis.conf配置文件位置:
/usr/local/app/redis-cluster/7000/redis.conf
/usr/local/app/redis-cluster/7001/redis.conf
/usr/local/app/redis-cluster/7002/redis.conf

注意修改redis.conf 内容 : 7000文件夹对应7000 ,7001对应7001 , 7002对应7002

  1. 编写redis实例启动脚本(三台机器都配置)
[root@localhost redis-cluster]# cd /usr/local/app/redis-cluster
[root@localhost redis-cluster]# vim start.sh
#/bin/bash
for ((i=0;i<3;i++));
do redis-server /usr/local/app/redis-cluster/700$i/redis.conf
done


[root@localhost redis-cluster]# chmod +x start.sh
[root@localhost redis-cluster]#start.sh
[root@localhost redis-cluster]# ps -ef |grep redis
root      2681     1  0 11:33 ?        00:00:00 redis-server 0.0.0.0:7000 [cluster]
root      2683     1  0 11:33 ?        00:00:00 redis-server 0.0.0.0:7001 [cluster]
root      2685     1  0 11:33 ?        00:00:00 redis-server 0.0.0.0:7002 [cluster]
root      2696  1508  0 11:33 pts/0    00:00:00 grep --color=auto redis

这时我们只是启动了9个单独的redis实例,它们还不是一个集群,下面就说明创建集群

  1. 构建集群

在一台机器上用redis-trib.rb 这个工具,就在redis解压目录的 src 目录中

[root@localhost src]# cd /usr/local/redis/src
[root@localhost src]#  ./redis-trib.rb create --replicas 1 172.29.2.10:7000 172.29.2.10:7001 172.29.2.10:7002 172.29.2.11:7000 172.29.2.11:7001 172.29.2.11:7002 172.29.2.12:7000 172.29.2.12:7001 172.29.2.12:7002

执行可能会报错

/usr/share/rubygems/rubygems/core_ext/kernel_require.rb:55:in require': cannot load such file -- redis (LoadError) from /usr/share/rubygems/rubygems/core_ext/kernel_require.rb:55:inrequire'
from ./redis-trib.rb:25:in `<main>'

原因就是安装redis-trib.rb运行依赖的ruby的包redis-4.1.3.gem

[root@localhost src]# gem install redis

但是又报错了

[root@localhost src]# gem install redis
Fetching: redis-4.2.5.gem (100%)
ERROR:  Error installing redis:
    redis requires Ruby version >= 2.3.0.

好家伙,很搞心态。于是我们又进行下面操作

[root@localhost src]# yum install curl
[root@localhost src]# curl -L get.rvm.io | bash -s stable

如果 上面步骤报错

curl: (7) Failed connect to raw.githubusercontent.com:443; 拒绝连接

说明dns解析被污染了,我们需要在https://www.ipaddress.com/查询raw.githubusercontent.com的真实IP,然后修改hosts

[root@localhost src]#vim /etc/hosts
199.232.96.133 raw.githubusercontent.com

继续执行

[root@localhost src]# curl -L get.rvm.io | bash -s stable

要等几分钟, 然而又会报错

[root@localhost src]# curl -L get.rvm.io | bash -s stable
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   194  100   194    0     0    256      0 --:--:-- --:--:-- --:--:--   256
100 24535  100 24535    0     0   9947      0  0:00:02  0:00:02 --:--:-- 21559
Downloading https://github.com/rvm/rvm/archive/1.29.11.tar.gz

Downloading https://github.com/rvm/rvm/releases/download/1.29.11/1.29.11.tar.gz.asc
gpg: 于 2020年12月29日 星期二 21时40分04秒 CST 创建的签名,使用 RSA,钥匙号 39499BDB
gpg: 无法检查签名:没有公钥
GPG signature verification failed for '/usr/local/rvm/archives/rvm-1.29.11.tgz' - 'https://github.com/rvm/rvm/releases/download/1.29.11/1.29.11.tar.gz.asc'! Try to install GPG v2 and then fetch the public key:

    gpg2 --keyserver hkp://pool.sks-keyservers.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB

or if it fails:

    command curl -sSL https://rvm.io/mpapis.asc | gpg2 --import -
    command curl -sSL https://rvm.io/pkuczynski.asc | gpg2 --import -

In case of further problems with validation please refer to https://rvm.io/rvm/security

此时我们需要这样

[root@localhost src]# gpg2 --keyserver hkp://pool.sks-keyservers.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB

然后继续执行

[root@localhost src]# curl -L get.rvm.io | bash -s stable

终于成功了


image.png

继续执行

[root@localhost src]# source /usr/local/rvm/scripts/rvm
[root@localhost src]# rvm install 2.4.0
[root@localhost src]# gem install redis

构建集群

[root@localhost src]# ./redis-trib.rb create --replicas 1 172.29.2.10:7000 172.29.2.10:7001 172.29.2.10:7002 172.29.2.11:7000 172.29.2.11:7001 172.29.2.11:7002 172.29.2.12:7000 172.29.2.12:7001 172.29.2.12:7002

测试连接

[root@localhost src]# redis-cli -c --raw -h 172.29.2.11 -p 7000
172.29.2.11:7000> set a 12
-> Redirected to slot [15495] located at 172.29.2.10:7001
OK

列出集群节点 cluster nodes

172.29.2.10:7001> cluster nodes
8652274729376e82f1a428e1925c58406957645a 172.29.2.10:7002@17002 slave 78601835e590953792faa9a727b0d2270c86b79e 0 1609738590000 4 connected
81cd0a98e5949d75b26622d2033060ea3d681c49 172.29.2.12:7000@17000 master - 0 1609738591000 7 connected 8192-12287
48483d9068b7666c6dac3fc9b02efe14e49a4bab 172.29.2.11:7002@17002 slave 81cd0a98e5949d75b26622d2033060ea3d681c49 0 1609738593251 7 connected
e13044c18301d106a5da98ea5cd13d02d859f43e 172.29.2.10:7000@17000 master - 0 1609738595272 1 connected 0-4095
509f037180874459355a818fcabe28095f007d26 172.29.2.10:7001@17001 myself,master - 0 1609738585000 2 connected 12288-16383
78601835e590953792faa9a727b0d2270c86b79e 172.29.2.11:7000@17000 master - 0 1609738593000 4 connected 4096-8191
d2334d3cd6bfca1a4a25ba4f959b7804f5ceb290 172.29.2.11:7001@17001 slave e13044c18301d106a5da98ea5cd13d02d859f43e 0 1609738594263 5 connected
5bef09d11868b12defed1d6dfc01c6f34b1bdc6f 172.29.2.12:7002@17002 slave 509f037180874459355a818fcabe28095f007d26 0 1609738592242 2 connected
a232ca2b2a62c1428f2ec5ff28c9d020002d4fbe 172.29.2.12:7001@17001 slave e13044c18301d106a5da98ea5cd13d02d859f43e 0 1609738591234 8 connected

查看集群信息 cluster info

172.29.2.10:7001> cluster info
cluster_state:ok
cluster_slots_assigned:16384
cluster_slots_ok:16384
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:9
cluster_size:4
cluster_current_epoch:9
cluster_my_epoch:2
cluster_stats_messages_ping_sent:507
cluster_stats_messages_pong_sent:496
cluster_stats_messages_meet_sent:5
cluster_stats_messages_sent:1008
cluster_stats_messages_ping_received:492
cluster_stats_messages_pong_received:512
cluster_stats_messages_meet_received:4
cluster_stats_messages_received:1008

到此,redis cluster模式已经搭建成功。

《 上善若水。水善利万物而不争,处众人之所恶,故几于道 》
释义:最善的人好像水一样。水善于滋润万物而不与万物相争,停留在众人都不喜欢的地方,所以最接近于“道”。

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

推荐阅读更多精彩内容