您好,欢迎访问一九零五行业门户网

Twemproxy – Twitter 开源的 Redis proxy

在去年的qcon london2012 大会上,twitter 发表了题为 《timelines @ twitter》的演讲,里面提到以 redis 作为其timeline的主要存储,目前目测全球范围内,twitter可能是redis的最大用户了(或者是新浪微博?)。 而今天我们要说的这个twemproxy,是 twitter
在去年的qcon london2012 大会上,twitter 发表了题为 《timelines @ twitter》的演讲,里面提到以redis作为其timeline的主要存储,目前目测全球范围内,twitter可能是redis的最大用户了(或者是新浪微博?)。
而今天我们要说的这个twemproxy,是 twitter 开源出来的 redis 和 memcached 代理。
功能介绍我们知道,无论是 memcached 还是当前的 redis,其本身都不具备分布式集群特性,当我们有大量 redis 或 memcached 的时候,通常只能通过客户端的一些数据分配算法(比如一致性哈希),来实现集群存储的特性。
而 twemproxy 通过引入一个代理层,可以将其后端的多台 redis 或 memcached 实例进行统一管理与分配,使应用程序只需要在 twemproxy 上进行操作,而不用关心后面具体有多少个真实的 redis 或 memcached 存储。
在 redis 的 cluster 方案还没有正式推出之前,通过 proxy 的方式来实现存储集群可能是最好的选择了。更何况 twemproxy 是通过 twitter 自身得到了充分检验的产品。
性能根据 redis 作者的测试结果,在大多数情况下,twemproxy 的性能相当不错,直接操作 redis 相比,最多只有20%的性能损失。这对于它带来的好处来说真的是微不足道了。唯一可能还有待改进的是其 mget 操作的效率,其性能只有直接操作 redis 的 50%。
安装与配置twemproxy 的安装有点小麻烦,主要命令如下:
apt-get install automakeapt-get install libtoolgit clone git://github.com/twitter/twemproxy.gitcd twemproxyautoreconf -fvi./configure --enable-debug=logmakesrc/nutcracker -h
通过上面的命令就算安装好了,然后是具体的配置,下面是一个典型的配置
redis1: listen: 0.0.0.0:9999 #使用哪个端口启动twemproxy redis: true #是否是redis的proxy hash: fnv1a_64 #指定具体的hash函数 distribution: ketama #具体的hash算法 auto_eject_hosts: true #是否在结点无法响应的时候临时摘除结点 timeout: 400 #超时时间(毫秒) server_retry_timeout: 2000 #重试的时间(毫秒) server_failure_limit: 1 #结点故障多少次就算摘除掉 servers: #下面表示所有的redis节点(ip:端口号:权重) - 127.0.0.1:6379:1 - 127.0.0.1:6380:1 - 127.0.0.1:6381:1 - 127.0.0.1:6382:1redis2: listen: 0.0.0.0:10000 redis: true hash: fnv1a_64 distribution: ketama auto_eject_hosts: false timeout: 400 servers: - 127.0.0.1:6379:1 - 127.0.0.1:6380:1 - 127.0.0.1:6381:1 - 127.0.0.1:6382:1
你可以同时开启多个 twemproxy 实例,他们都可以进行读写,这样你的应用程序就可以完全避免所谓的单点故障。
问题与不足twemproxy 由于其自身原理限制,有一些不足之处,如:
不支持针对多个值的操作,比如取sets的子交并补等(mget 和 del 除外)不支持redis的事务操作出错提示还不够完善更多更多关于twemproxy的介绍可以看这里:http://antirez.com/news/44
twemproxy的项目地址:https://github.com/twitter/twemproxy
42区 vps
42qu.com 云主机 , 卖给创业的你 。 点击这里 ,
warning: call_user_func_array() expects parameter 1 to be a valid callback, function 'embed_rssfooter' not found or invalid function name in /home/b55/htdocs/blog.nosqlfan.com/wp-includes/plugin.php on line 166
其它类似信息

推荐信息