阅读更多

0顶
0踩

数据库
在去年的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 automake
apt-get install libtool
git clone git://github.com/twitter/twemproxy.git
cd twemproxy
autoreconf -fvi
./configure --enable-debug=log
make
src/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:1

redis2:
  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
来自: NoSQLFan
0
0
评论 共 2 条 请登录后发表评论
2 楼 newboy2004 2013-01-22 10:29
没准在以后的项目中就可以想到使用它
1 楼 highkay 2013-01-21 21:57
有一个致命的问题,节点动态变化以后,存储的内容不能自动的rehash,非常蛋疼啊。

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • Redis集群方案对比:Codis、Twemproxy、Redis Cluster

    为了保证Redis的高可用,主要需要以下几个方面: 数据持久化 主从复制 自动故障恢复 集群化 我们简单理一下这几个方案的特点,以及它们之间的联系。 数据持久化本质上是为了做数据备份,有了数据持久化,当...

  • Twemproxy – Twitter 开源的 Redis proxy

    Twemproxy – Twitter 开源的 Redis proxy 作者:nosqlfan on 星期天, 一月 20, 2013 · 评论本文 【阅读:9,850 次】 在去年的QCon London2012 大会上,Twitter 发表了题为 《Timelines @ Twitter》的演讲,里面...

  • redis2.6+twemproxy+zookeeper配置redis节点

    redis + zookeeper + twemproxy 安装不在此赘述 第一节 Redis启动 本节参考自:https://www.cnblogs.com/gomysql/p/3617238.html /usr/local/redis2.6/conf 下配置 文件7100.conf (主),以下是关键配置信息,...

  • twemproxy---redis/memcache代理

    Use 0.0.0.0 on the listen command to tell ...当使用node_redis连接twemproxy的时候,node_redis默认会向redis服务端发送“info”信息来确认server状态是否是ready,而twemproxy是不支持的,所以要在连接redis的

  • 八、twemproxy实现redis集群

    Twemproxy也叫nutcraker,是twtter开源的一个redis和memcache代理服务器程序。redis作为一个高效的缓存服务器,非常具有应用价值。但在用户数据量增大时,需要运行多个redis实例,此时将迫切需要一种工具统一管理多...

  • Redis分片代理twemproxy快速搭建 | twemproxy Demo | twitter/ twemproxy 避坑指南 | autoconf-2.69下载

    redis代理主要有:predixy、twemproxy、codis、redis-cerberus。他们作为代理,高性能这方面,都是牛逼class,相对而言predixy的功能更为强大一点,在延时上,codis由于语言的问题,略逊一筹,本文重点介绍twemproxy...

  • Redis(五)集群化方案对比:Codis、Twemproxy、Redis Cluster

    Redis(五)集群化方案对比:Codis、Twemproxy、Redis Cluster 之前我们提到,为了保证Redis的高可用,主要需要以下几个方面: 数据持久化 主从复制 自动故障恢复 集群化 我们简单理一下这几个方案的特点,以及它们...

  • redis第八课-AKF之Y轴-分片,代理之twemproxy,predixy,redis-cluster的使用搭建

    上篇我们主要讲解了一下redis使用AKF拆分之X轴的实践,也就是有点像副本式存储。 但光有X轴还不够,因为存储容量是克隆式的,存储的内容都一样,因此还是存在容量受限的问题。 因此,今天讲的就是redis基于AKF在Y轴...

  • Redis 集群之Redis+Twemproxy方案

    1、下载Redis安装包 Redis的官网下载地址是https://redis.io/download,上面有各个发行版本,我选择的是当前的最新稳定版5.0.4,下载到安装目录并编译出安装包。 wget ...

  • 在Linux部署Redis代理Twemproxy实现数据分片

    通过Redis代理实现横向扩展,再也不用担心数据量大了

  • 基于 Twemproxy 与 Codis 的 redis 集群方案比较

    redis 集群和搭建方法。 redis 集群详解及搭建过程 事实上,第三种 redis 原生的 redis-cluster 同时具备了前两种的特性,既能够实现主备也能够实现故障时的...

  • Redis+Twemproxy+HAProxy集群

    Redis数据库与传统数据库属于并行关系,也就是说传统的关系型数据库保存的是结构化数据,而Redis保存的是一些所谓的 临时 数据,因为Redis具备一项很强的功能 持久化数据 ,发现Redis好像也可以做一些传统数据库的...

  • Twemproxy代理Redis-cluster

    是一个twtter开源的一个redis和memcache代理服务器。 redis作为一个高效的缓存服务器,非常具有应用价值。但是当使用比较多的时候,就希望可以通过某种方式 统一进 行管理。避免每个应用每个客户端管理连接的松散性...

  • 基于twemproxy的redis集群方案实践

    Twemproxy又名nutcraker,是由Twtter 开源,是一种代理分片机制的中间件(类似于mycat),主要用于管理 Redis Memcached 集群,可接受来自多个客户端的请求,按照路由规则,转发给后端cache节点,减少了客户端与...

  • Redis(持久化、主从复制、主从切换、twemproxy、redis集群)

    文章目录Redis Redis redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型...

  • Twemproxy对redis集群进行代理实现高可用

    Redis集群后的高可用性,Twemproxy是一种代理分片机制,由Twitter开源。Twemproxy作为代理,可接受来自多个程序的访问,按照路由规则,转发给后台的各个Redis服务器,再原路返回。该方案很好的解决了单个Redis实例...

  • Redis核心技术-高可靠-集群方案(客户端分片、代理分片、Redis Cluster)

    Redis在3.0版本前只支持单实例模式,虽然Redis的开发者Antirez早在博客上就提出在Redis 3.0版本中加入集群的功能,但3.0版本等到2015年才发布正式版。...包括:客户端分片、代理分片、Redis Cluster。

  • Twemproxy——针对MemCached与Redis的代理

    Twemproxy是一个代理服务器,可以通过它减少Memcached或Redis服务器所打开的连接数。 Twemproxy有何用途呢?它可以: 通过代理的方式减少缓存服务器的连接数 自动在多台缓存服务器间共享数据 通过不同的策略与散列...

  • 基于springboot大学生就业信息管理系统源码数据库文档.zip

    基于springboot大学生就业信息管理系统源码数据库文档.zip

  • 基于java的驾校收支管理可视化平台的开题报告.docx

    基于java的驾校收支管理可视化平台的开题报告

Global site tag (gtag.js) - Google Analytics