redis6高可用集群搭建

最近发现redis的内存空间不够实用了,发现是服务器太旧了导致乱七八糟的都占了不少存储和内存。而且服务器的性能也比较差。但是服务器还是蛮多的(5台左右),如果说换新的又可惜。所以找了一种redis集群的搭建方式来部署redis高可用集群环境。以下就是搭建的过程。给自己做一个总结和笔记。

准备环境

1.redis-6.0.5
2.三台服务器 10.172.246.231、10.172.246.232、10.172.246.233 (231、232、233)

一、下载redis到服务器

可以自行去官网下载redis然后上传的服务器中,如果服务器可以连接外网则可以直接使用官方提供的链接来下载
wget http://download.redis.io/releases/redis-6.0.5.tar.gz
本人使用的是redis的最新版本 6.0.5
并解压到指定目录
tar xzf redis-6.0.5.tar.gz

二、在各个服务器上安装解压后的redis

官网上说明的是直接在压缩后的文件夹中使用make

$ wget http://download.redis.io/releases/redis-6.0.5.tar.gz
$ tar xzf redis-6.0.5.tar.gz
$ cd redis-6.0.5
$ make

但是我本地并没有安装gcc和tcl所以先进行安装后再make

使gcc 9 作为长久运行版本

$ yum install tcl
$ yum -y install centos-release-scl
$ yum -y install devtoolset-9-gcc devtoolset-9-gcc-c++ devtoolset-9-binutils
$ scl enable devtoolset-9 bash
$ echo "source /opt/rh/devtoolset-9/enable" >>/etc/profile

$ cd redis-6.0.5
$ make 
$ make install

三、在每台服务器上拷贝两个实例,然后修改配置文件

服务器 主备关系 端口
231 33331
232 33332
233 33333
231 备 --> 232.33332 33334
232 备 --> 233.33333 33335
233 备 --> 231.33331 33336

Redis 集群有16384个哈希槽,每个key通过CRC16校验后对16384取模来决定放置哪个槽.集群的每个节点负责一部分hash槽
所以通常的redis集群在某一个节点挂掉后都会导致集群不可用。而这样三台服务器做集群时就可以保证在任意一台服务器挂了的情况下redis集群都可以正常运行(因为备节点和主节点不在同一台服务器上)。

1.新建对应文件夹,放入redis-server和redis.conf文件

$ mkdir reids01 redis04
$ cp redis-6.0.5/src/redis-server /redis01
$ cp redis-6.0.5/src/redis-server /redis04

$ cp redis-6.0.5/redis.conf /redis01
$ cp redis-6.0.5/redis.conf /redis04

2.修改各自的配置文件(只展示需要修改的部分)

$ vim redis01/redis.conf

#是否开启保护模式,默认开启。要是配置里没有指定bind和密码。开启该参数后,redis只会本地进行访问,拒绝外部访问。
protected-mode no
#redis监听的端口号
port 33331
#是否在后台执行,yes:后台运行;no:不是后台运行
daemonize yes
#redis的进程文件
pidfile /var/run/redis_33331.pid
# 指定了记录日志的文件。空字符串的话,日志会打印到标准输出设备。后台运行的redis标准输出是/dev/null
logfile /usr/local/redis/redis01/redis33331.log
# 指定本地数据库文件名,一般采用默认的 dump.rdb
dbfilename dump33331.rdb
# 数据目录,数据库的写入会在这个目录。rdb、aof文件也会写在这个目录
dir ./
# 集群
cluster-enabled yes
# 生成的node文件,不过不指定名称则直接为nodes.conf。在同一台服务器上启动第二个实列的时候就会报错。因为nodes.conf文件发生冲突
cluster-config-file nodes33331.conf

修改的配置名称需要自行灵活修改 如:端口为33332则上文中33331的地方均需要改为33332
也可以根据自己的需要来进行修改但是需要注意的是
同一台服务器上的cluster-config-file、dbfilename 名称不能一致、IP端口也不能一致

再修改完后启动各个服务器上的实列

四、创建集群

根据网上说的使用Ruby创建集群时 在6.0.5里面会给你提示,让你使用redis-cli创建集群,并会提示给你使用的语句使其和redis-trib.rb达到一致的效果(可以不用再单独的安装Ruby)

操作截图

原本使用redis-trib.rb的语句

$ ./redis-trib.rb create --replicas 1 10.172.246.231:33331 \
10.172.246.232:33332 \
10.172.246.233:33333 \
10.172.246.232:33335 \
10.172.246.233:33336 \
10.172.246.231:33334

提示使用的redis-cli语句(最好自己打 ,因为我是自己打的。到时候少空格或符号别bb ~~)

$ ./redis-cli --cluster create 10.172.246.231:33331 \
10.172.246.232:33332 \
10.172.246.233:33333 \ 
10.172.246.232:33335 \
10.172.246.233:33336 \
10.172.246.231:33334 \
--cluster-replicas 1 

可以看出两个语句都差不多,而且语句意思也差不多
--cluster-replicas 表示主备的比例关系 1 表示一个主节点对应一个备节点
前三个 ip:port 默认表示主节点,后面的依次为前三个主节点的备份节点

(敲黑板)(敲黑板)(敲黑板)注意 : 我这里第4个节点写的时232:33335而不是231:33334因为 第四个节点是第一个节点的备节点,为了保证高可用(在任意一台服务器挂了的情况下都不影响redis集群的使用)所以主备节点不可以在同一台服务器上(如果主备节点在同一台服务器上则备节点也没有太大的意义了)。所以要错开对应。
如:在231服务器挂了的情况下 231:33331的备节点为233:33336。这时备节点充当主节点继续工作。可以使redis集群正常运行。

集群搭建

它会罗列出集群的对应关系来让你确定。输入 yes完成集群创建。

五、测试

测试

可以看到放入的哈希槽为 [12182]也属于233:33333所管控的节点,所以就直接跳转到233:33333来获取刚才放入的数据

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