Redis读性能优化

本文介绍提升Redis读性能的两种主要方法:一是优化数据查询方式,包括使用pipeline、连接池及选择合适的数据结构;二是通过添加只读从服务器来增强读取能力,并探讨了主从服务器架构下的重同步问题及解决方案。

首先提一个问题,一个Redis进程每秒能处理的最大请求数目是多少?

答: 能处理的请求数目大概是10W/秒。使用pipeline后,处理请求数目可以达到50W/秒。(具体数值不是我测试的,我谷歌来的

言归正传,提升Redis读性能有两个方面: 数据查询方式优化 和 增加只读服务器。


A.

数据查询方式的优化有以下几个途径:

a. 建议使用pipeline查询;

b. 建议使用连接池;

c. 使用短结构优化内存占用时,不建议压缩列表的长度过大,会影响查询性能;

d. 数据结构方面,应使用最优的数据结果来使用。例如: 不建议把列表当集合使用;

 

B.

除了正确的使用数据查询方式以外,提升redis读取能力最简单的方法,就是添加只读从服务器

但是,主从服务器架构存在一个最棘手的问题: 主服务器挂掉。


C. 从服务器重同步问题

当存在多个从服务器从一个主服务器同步时,面临一个问题: 主服务器带宽占用过高,导致主服务器延迟变高,甚至网络中断,以上这个问题叫做服务器重同步问题(resync)。

解决重同步问题,核心是减少主服务器需要传送给从服务器的数据数量。 


一个方法是使用从服务器树,举例如下:

a. 常规情况1个主带9个从。

b. 从服务器树就是将服务器分为两层,顶层主机带三台从机,这三台从机构成一个中间层,三台从机再分别各自带三台从机。


使用从服务器树好处:

1.通过缓慢的公网(广域网)进行数据同步非常耗时耗资源,这种工作交给中间层服务器要好于交给顶层服务器;

使用从服务器树坏处:

1.树形网络拓扑结构增加了结构复杂度,当出现故障时,增加了处理难度; 


另一个方法是对网络连接进行压缩. (此方法我不太熟,没有实际操作过)

a. 使用ssh隧道进行连接,似乎OpenVPN是一个比较好的方法; 



转载请标明出处:http://my.oschina.net/justfairytale/blog/667902


转载于:https://my.oschina.net/justfairytale/blog/667902

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值