Redis 代理集群方案

安装环境:centos7,redis6

twemproxy

大致流程操作
  1. 浏览twemproxy的github官方网站,阅读里面的readme

  2. 使用git clone https://github.com/twitter/twemproxy.git 下载源码

    image.png

  3. cd twemproxy ,执行autoreconf 命令的时候提示没有该命令,根据README里面的信息,需要安装automake和libtool


    image.png
  4. 安装 automake和libtool


    image.png
  5. 执行 autoreconf -fvi


    image.png

查看目录,可以看到多了个configure 可执行文件


image.png
  1. 执行 ./configure --enable-debug=full
    成功执行后可以看到 Makefile,前面一系列操作都是为了获取Makefile 文件,执行make 操作
image.png
  1. 执行make 操作,成功执行后,在src目录下多了个执行文件


    image.png
  2. 查看scripts/nutcracker.init 的文件


    image.png
  3. cp nutcracker.init /etc/init.d/twemproxy & cd /etc/init.d/ & chmod +x twemproxy
    服务启动的时候需要执行这个脚本

  4. 根据nutcracker.init 里面的 ,需要创建/etc/nutcracker 目录,并添加nutcraker.yml 文件

在 /twemproxy/conf目录下把 nutcraker.yml 文件拷贝过去

cp nutcracker.yml /etc/nutcraker/
  1. cp src/nutcracker /usr/bin 把可执行命令拷贝到bin下面,就可以在任何目录下执行 nutcracker 命令了

  2. 编辑/etc/nutcracker/nutcraker.yml 文件


    image.png

启动相应的redis服务


image.png
  1. 使用 service twemproxy start 启动服务 ,因为前面把nutcraker 改名成twemproxy 了。


    image.png
  2. 使用redis-cli 命令连接代理服务器ip端口


    image.png

使用命令验证


image.png
image.png
image.png
  1. 总结


    image.png

    可以加上hash_tag 的标签,让标签里面一下的key,可以到同一个redis实例中,twemproxy 做代理的时候事务不支持,有一些聚合命令也不支持:keys * ,PSUBSCRIBE * 等

predixy

支持redis sentinel 和redis cluster

  1. predixy github官方地址

  2. 下载编译好的tar包

# 下载
wget https://github.com/joyieldInc/predixy/releases/download/1.0.5/predixy-1.0.5-bin-amd64-linux.tar.gz

# 解压缩
tar xf predixy-1.0.5-bin-amd64-linux.tar.gz 
  1. 修改/conf/predixy.conf 配置文件


    image.png
image.png
  1. 配置sentinel 模式,修改sentinel.conf 的配置文件


    image.png

    里面 Group 的名称应该要和redis sentinel 的名称一样

  2. 启动3个redis sentinel 服务

redis-server /root/soft/sentinel/26379.conf --sentinel
redis-server /root/soft/sentinel/26380.conf --sentinel
redis-server /root/soft/sentinel/26381.conf --sentinel

  1. 启动4条redis server 服务,两主两从
redis-server --port 36379
redis-server --port 36380 --replicaof 127.0.0.1 36379
redis-server --port 46379
redis-server --port 46380 --replicaof 127.0.0.1 46379

  1. 启动predixy 服务
./predixy ../conf/sentinel.conf
image.png
  1. 使用redis-cli 客户端口连接 predixy 代理
redis-cli -p 7617
  1. 总结

predixy 代理只支持单sentinel 的事务 ,多个sentinel 不支持事务

redis cluster

  1. 进到源码包中utils/create-cluster目录下,使用create-cluster 快速启动redis cluster 实例,

  2. 使用 ./create-cluster start 创建6个redis实例

  3. 使用 ./create-cluster create 分配槽位


    image.png
  4. 使用redis-cli 进行连接

redis-cli -c  -p 30001

  1. 停止和清除
 ./create-cluster stop
 ./create-cluster clean
  1. 启动6台服务后,需要使用命令来创建集群
redis-cli --cluster create 127.0.0.1:30001 127.0.0.1:30002 127.0.0.1:30003 127.0.0.1:30004 127.0.0.1:30005 127.0.0.1:30006 --cluster-replicas 1

image.png
  1. 总结

redis cluster 模式中只要事务中的key在同一条机器上,就可以正常执行

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

推荐阅读更多精彩内容

  • 1、 高可用Sentinel(单主 Redis 足以支撑业务,保证数据安全,业务前期数据少可用,目)ps:主从只是...
    hedgehog1112阅读 315评论 0 1
  • Redis集群方案 通常,为了提高网站响应速度,总是把热点数据保存在内存中而不是直接从后端数据库中读取。Redis...
    jiangmo阅读 597评论 0 3
  • 【转载请注明出处】://www.greatytc.com/p/d94728fc8a91 1、下载Redi...
    后端老鸟阅读 871评论 0 0
  • 单机/单点 单点故障/瓶颈:多个节点负载:面向数据:一变多(一致性<弱一致,最终一致性>)》可用性最终一致性:一部...
    壹点零阅读 790评论 0 3
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 7,522评论 16 22