网易首页 > 新闻中心 > 滚动新闻 > 正文

环信实操干货:pika新特性支持codis slot迁移

0
分享至

(原标题:环信实操干货:pika新特性支持codis slot迁移)

  

简介:已经有越来越多的公司在线上使用pika. pika兼容redis协议,之前版本已经支持作为codis的server,但是由于不支持codis的slot迁移操作,所以还不能在线动态扩容。现在pika的codis分支已经支持codis的slot迁移,目前该版本已经在环信线上稳定运行, 每天承载数亿的访问量, 这个大feature 由环信云乾同学开发测试完成。

张云乾童鞋内部分享

环信即时通讯云使用案例

背景介绍

pika在环信的即时通讯云平台系统中使用,用来存储消息内容和日志,目前在部分集群中数据量已经达到数TB,QPS在数十万级别。这些数据最早存储在mysql里面,但mysql性能有限,而且扩容不方便。我们评估了下codis,能解决我们在mysql里面面临的性能及扩容问题,在一段时间用codis存储这些数据。但随着数据量级增长,TB级别的数据存储在内存里面,成本过于昂贵。后来了解到pika数据存储在磁盘里面,而且兼容redis协议及命令,可以挂载在codis proxy后面做server,这样既保留codis proxy的高性能,又能解决TB级数据量的存储成本问题。但pika还不支持codis的slot迁移,当压力上涨时,扩容是个问题。通过研究codis及pika的实现,在pika上开发实现了codis的slot迁移。目前已在生产环境中使用,运行良好,考虑到该功能能帮助更多的人解决一些实际的问题,我们经过再三测试验证后向官方提交了PR

线上数据

支持slot迁移版本的pika已经在环信的生产环境中使用,获得了一些线上环境的数据:

当pika容量在500G时,全量同步一次的时间大概在7个小时左右(千M网卡)

运行slotsreload命令每秒钟处理key的数据在万级,所以上面针对过期数据使用支持slot迁移的方式是可行的,已经过线上环境验证。

在进行slot迁移时,每秒钟迁移的key数量在200~300之间,当数据量大时,迁移需要花费很长时间,但迁移期间不影响线上业务正常使用。

codis多连接版本可以提升性能2~3倍,完全释放pika的性能

pika codis slot 功能介绍

部署方法

codis部署方式没有改动,只是在添加codis-server(redis)的地方部署上支持codis slot迁移的pika,该版本pika部署和之前的pika部署方式一样,只是配置文件中需要添加一样,以打开支持迁移的开关:

# slotmigrate [yes | no]

slotmigrate : yes

使用方法

部署成功后即可进行使用,和官方的codis没有任何不同,一个大的可以扩容的redis。当codis-server(pika)压力过大需要扩容的使用,按照官方的迁移方法进行slot迁移即可。

带来好处

codis-server集群可以在不停机的情况下进行水平扩容

dbsize命令可以实时获取当前数据库(pika)中key的数量

注意事项

slot迁移开关

出于和pika之前官方版本更好的兼容,以及用户升级到支持迁移的pika版本操作更方便的考虑。在设计实现pika支持codis slot迁移时,设计并实现了slot迁移开关,该开关可以通过配置文件进行开关或者关闭(即上面配置文件改动的地方,yes是打开,no是关闭),也可以通过redis-cli的config set slotmigrate进行在线的打开或者关闭:

$ redis-cli -h 127.0.0.1 -p 9221 config set slotmigrate yes

$ redis-cli -h 127.0.0.1 -p 9221 config set slotmigrate no

当关闭开关时,pika不支持slot迁移,和之前版本的pika没有区别(dbsize也不能实时获取);当打开开关时,支持slot迁移(dbsize能实时获取),但需要有以下几点注意:

pika打开slot迁移开关后,磁盘容量会有10%~30%的增加,性能会有10%~15%的下降

如果是一个全新的数据库,里面没有数据,在配置文件中打开了迁移开关,即可进行使用和随时进行slot迁移;如果数据库里面已经有数据,通过暂时关机更改配置文件打开开关或者通过命令行打开开关(已立即可以进行正常使用),在进行slot迁移前要先在命令行运行slotsreload命令,

127.0.0.1:9221> slotsreload

该命令是一个在后台运行的命令,类似bgsave模式,可以通过info命令查看slotsreload是否运行结束,在运行结束后才可以进行迁移。

如果数据库使用的场景中,有大量过期数据,大量使用expire等设置key过期的命令,建议不要在配置文件中打开开关(那些过期的数据,在slot里面没有进行过期删除,会导致数据累积,后面会考虑改进这点),可以考虑在需要迁移前在命令行打开开关,然后运行slotsreload命令,在slotsreload命令运行结束后,进行迁移,迁移完成后在命令行运行slotsdel命令进行收尾工作(释放磁盘占用),命令后面跟需要清理掉slot,如下方式

$ 127.0.0.1:9221> slotsdel 1013 990

额外开销

如上面所说,pika支持slot迁移会使用更多一些的磁盘,性能上会有一些下降。如果对磁盘使用或者性能有很高的要求,则可以按照上面3针对过期数据的使用方式进行使用。

同名不同类型的key

pika支持同名的key有kv,hash,list,set, zset等5种类型,但如果要使用pika支持slot迁移,不要使用同名但不同类型的key,如不要:set test1 100后再lpush test1 a b c,产生同名不同类型的key。在支持slot迁移的pika中使用同名但不同类型的key,迁移的时候会丢失那些同名的key。

codis多连接

codis 2.0及之前版本proxy和后端server是使用的单连接,当后端server是redis时,这个性能还是很不错的,但当后面是pika、ssdb等磁盘数据库时,单连接严重限制了后端server的性能,需要让codis支持多连接,针对多连接这个问题的讨论见:https://github.com/CodisLabs/codis/pull/1007

该讨论提供了两种解决方法:

如果是codis 2.0版本可以使用https://github.com/left2right/codis ,编译后在proxy的配置文件中作如下增加;

# Proxy connections number model with backend server: server/slot, server means only one connection between proxy and backend server,

# slot means every slot has one connection between proxy and backend server, default is server

backend_connection_model=server

如果是codis 3.1版本,可以使用官方版本,并打开多连接,该版本多连接的实现见:

总结

pika支持codis slot迁移版本带来了一些好处,如动态水平扩容,dbsize实时获取,也带来了一些开销,如磁盘和性能。但它提供了一个开关,一个供你在这之间可以进行权衡的开关;它同时为pika的水平扩展提供了一个选择,一个当你的数据量快速增长带来问题时无痛解决问题的选择。

关于Pika

Pika是360 DBA和基础架构组联合开发的类redis存储系统, 使用Redis协议,兼容redis绝大多数命令(String,Hash,List,ZSet,Set),用户不需要修改任何代码, 就可以将服务迁移至pika。pika主要是使用持久化存储来解决redis在内存占用超过50G,80G时遇到的如启动恢复时间长,主从同步代价大,硬件成本贵等问题,并且在对外用法上尽可能做到与redis一致,用户基本上对后端是redis或pika无感知

(原标题:环信实操干货:pika新特性支持codis slot迁移)

相关推荐
热点推荐
鹿晗高清生图出炉,客观说,作为男明星,这状态什么水平?

鹿晗高清生图出炉,客观说,作为男明星,这状态什么水平?

娱乐的小灶
2024-04-25 21:15:09
江苏银行业绩发布会上 股价几近跌停 发生了什么

江苏银行业绩发布会上 股价几近跌停 发生了什么

金融界
2024-04-26 18:36:07
神十八航天员李广苏家庭曝光:母亲在家务农,母子俩已多年未见

神十八航天员李广苏家庭曝光:母亲在家务农,母子俩已多年未见

搞笑的阿票
2024-04-26 17:40:53
他是比肩钱钟书的天才,却被灌污水整死了

他是比肩钱钟书的天才,却被灌污水整死了

谢小楼
2024-04-22 16:19:01
如何面对九二共识?赖清德给出终极答案,台军方助威,国台办回应

如何面对九二共识?赖清德给出终极答案,台军方助威,国台办回应

DS北风
2024-04-25 18:00:11
中药又立功?蒲公英可杀死98%癌细胞、消除结节?揭开研究真相

中药又立功?蒲公英可杀死98%癌细胞、消除结节?揭开研究真相

荆变果
2024-04-24 14:25:40
入夏一定要补阳,不然一年都白忙,记得吃“暖阳3宝”。

入夏一定要补阳,不然一年都白忙,记得吃“暖阳3宝”。

今日养生之道
2024-04-25 00:37:11
英媒:曼联相信6000万-7000万英镑的报价足以签下布兰斯韦特

英媒:曼联相信6000万-7000万英镑的报价足以签下布兰斯韦特

懂球帝
2024-04-25 21:15:08
辛巴快手账号直播权限将于5月20日解封

辛巴快手账号直播权限将于5月20日解封

三言科技
2024-04-26 12:30:09
陈梦王楚钦恋情实锤?陈梦父母开豪车接机,看王楚钦举动就懂了

陈梦王楚钦恋情实锤?陈梦父母开豪车接机,看王楚钦举动就懂了

东球弟
2024-04-25 18:52:44
艾克森目前处境尴尬,夏窗是离开蓉城的最佳节点,潜在下家曝光

艾克森目前处境尴尬,夏窗是离开蓉城的最佳节点,潜在下家曝光

开心体育站
2024-04-26 16:42:54
3-1!广东淘汰广厦!赛后听听京媒,粤媒,辽媒和沪媒怎么说

3-1!广东淘汰广厦!赛后听听京媒,粤媒,辽媒和沪媒怎么说

邹维体育
2024-04-25 22:14:31
身上有这三种记号的人,多半人狠心黑,别深交

身上有这三种记号的人,多半人狠心黑,别深交

闻心品阁
2024-04-26 21:08:42
谭秦东:我就是个没有靠山的软柿子!

谭秦东:我就是个没有靠山的软柿子!

大众新闻报社记者
2024-04-25 10:22:33
拉黑汪小菲、抚养费不要,让孩子丢掉生日礼物,大S这次铁了心了

拉黑汪小菲、抚养费不要,让孩子丢掉生日礼物,大S这次铁了心了

七阿姨爱八卦
2024-04-25 16:59:55
新华社快讯:以色列25日宣布,美国在加沙地带开工建设码头,以军提供“安全和后勤支持”。

新华社快讯:以色列25日宣布,美国在加沙地带开工建设码头,以军提供“安全和后勤支持”。

新华社
2024-04-26 03:39:06
历史上功高震主的三位名将,完全可以取代皇帝,为何结局截然不同

历史上功高震主的三位名将,完全可以取代皇帝,为何结局截然不同

纪实社会百态
2023-12-01 11:22:21
还是柳岩以前比较大方自信!

还是柳岩以前比较大方自信!

曼妙观
2024-04-23 13:34:17
王庭惠辞职

王庭惠辞职

鲁中晨报
2024-04-26 18:41:12
皮奥利:国米过去4年阵容都是意甲最强 但也只拿了两次冠军

皮奥利:国米过去4年阵容都是意甲最强 但也只拿了两次冠军

直播吧
2024-04-26 18:00:27
2024-04-26 22:00:49

头条要闻

德国驻华大使称被中国外交部召见 外交部回应

头条要闻

德国驻华大使称被中国外交部召见 外交部回应

体育要闻

库里当选最佳关键球员 10项数据联盟第一

娱乐要闻

金靖回应不官宣恋情结婚的原因

财经要闻

贾跃亭,真他娘是个人才

科技要闻

车展观察|德系日系绝不能放弃中国市场

汽车要闻

2024北京车展 比亚迪的自驱力让对手紧追猛赶

态度原创

教育
时尚
艺术
数码
本地

教育要闻

小心题目中的陷阱,稍微不细心犯错

不建议50+女人戴的帽子!自以为洋气,实际大妈味十足,油腻老气

艺术要闻

日居月諸:莊聲濤新墨作品展

数码要闻

249元!小米推出米家无线智能宠物饮水机:接入澎湃 充电一次用4个月

本地新闻

蛋友碰碰会空降西安!5.1山海境等你!

无障碍浏览 进入关怀版
×