`
cfyme
  • 浏览: 263236 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Redis 代理服务Twemproxy

 
阅读更多

1、twemproxy explore

      当我们有大量 Redis 或 Memcached 的时候,通常只能通过客户端的一些数据分配算法(比如一致性哈希),来实现集群存储的特性。虽然Redis 2.6版本已经发布Redis Cluster,但还不是很成熟适用正式生产环境。 Redis 的 Cluster 方案还没有正式推出之前,我们通过 Proxy 的方式来实现集群存储。

       Twitter,世界最大的Redis集群之一部署在Twitter用于为用户提供时间轴数据。Twitter Open Source部门提供了Twemproxy。

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

      Twemproxy是一个快速的单线程代理程序,支持Memcached ASCII协议和更新的Redis协议:

     它全部用C写成,使用Apache 2.0 License授权。项目在Linux上可以工作,而在OSX上无法编译,因为它依赖了epoll API.

      Twemproxy 通过引入一个代理层,可以将其后端的多台 Redis 或 Memcached 实例进行统一管理与分配,使应用程序只需要在 Twemproxy 上进行操作,而不用关心后面具体有多少个真实的 Redis 或 Memcached 存储。 

2、twemproxy特性:

  • 支持失败节点自动删除

    • 可以设置重新连接该节点的时间
    • 可以设置连接多少次之后删除该节点
    • 该方式适合作为cache存储
  • 支持设置HashTag

    • 通过HashTag可以自己设定将两个KEYhash到同一个实例上去。
  • 减少与redis的直接连接数

    • 保持与redis的长连接
    • 可设置代理与后台每个redis连接的数目
  • 自动分片到后端多个redis实例上

    • 多种hash算法:能够使用不同的策略和散列函数支持一致性hash。
    • 可以设置后端实例的权重
  • 避免单点问题

    • 可以平行部署多个代理层.client自动选择可用的一个
  • 支持redis pipelining request

         支持请求的流式与批处理,降低来回的消耗 

  • 支持状态监控

    • 可设置状态监控ip和端口,访问ip和端口可以得到一个json格式的状态信息串
    • 可设置监控信息刷新间隔时间
  • 高吞吐量

    • 连接复用,内存复用。
    • 将多个连接请求,组成reids pipelining统一向redis请求。

     另外可以修改redis的源代码,抽取出redis中的前半部分,作为一个中间代理层。最终都是通过linux下的epoll 事件机制提高并发效率,其中nutcraker本身也是使用epoll的事件机制。并且在性能测试上的表现非常出色。

3、twemproxy问题与不足

 
Twemproxy 由于其自身原理限制,有一些不足之处,如:  
  • 不支持针对多个值的操作,比如取sets的子交并补等(MGET 和 DEL 除外)
  • 不支持Redis的事务操作
  • 出错提示还不够完善
  • 也不支持select操作

4、安装与配置 

具体的安装步骤可用查看github: https://github.com/twitter/twemproxy
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:127.0.0.1:6379#使用哪个端口启动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: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 实例,它们都可以进行读写,这样你的应用程序就可以完全避免所谓的单点故障。  
 
分享到:
评论

相关推荐

    Redis 存储分片之代理服务Twemproxy 测试.pdf

    Redis 存储分片之代理服务Twemproxy 测试.pdfRedis 存储分片之代理服务Twemproxy 测试.pdf

    twemproxy:这是一个 redis 代理,其主要功能就是在多个 redis 节点和访问者之间做路由分发

    twemproxy:这是一个 redis 代理,其主要功能就是在多个 redis 节点和访问者之间做路由分发:访问者不需要自己判断某个 key 该存储到哪一个 redis 节点或者该到哪个节点去获取某个 key 的值——这是一个负载均衡组件

    laravel项目利用twemproxy部署redis集群的完整步骤

    twemproxy是twitter开发的一个redis代理proxy,Twemproxy可以把多台redis server当作一台使用,开发人员通过twemproxy访问这些redis servers 的时候不用关心到底去哪一台redis server读取k-v数据或者把k-v数据更新到...

    Twemproxy 安装过程

    redis集群代理Twemproxy 安装过程,Twemproxy是一个专门为了这种nosql数据库设计的一款代理工具软件,这个工具软件最大的特征是可以实现数据的分片处理。所谓的分片指的是根据一定的算法将要保存的数据保存到不同的...

    twemproxy-master.zip

    使应用程序只需要在Twemproxy上进行操作,而不用关心后面具体有多少个真实的Redis或Memcached存储,有了Twemproxy,客户端不直接访问Redis服务器,而是通过twemproxy 代理中间件间接访问。此包是用于安装redis的...

    cpp-twemproxy一个memcached和redis的快速轻量级代理

    twemproxy:一个memcached和redis的快速,轻量级代理

    cpp-美团twemproxy是memcached和redis协议的多进程快速和轻量级代理

    美团twemproxy是memcached和redis协议的多进程,快速和轻量级代理

    twemproxy:一个快速、轻量级的 memcached 和 redis 代理-开源

    twemproxy(发音为“two-em-proxy”),又名 nutcracker 是 memcached 和 redis 协议的快速轻量级代理。 它的构建主要是为了减少与后端缓存服务器的连接数。 这与协议流水线和分片一起使您能够水平扩展分布式缓存...

    twemproxy应用包

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

    beholder:twemproxy 代理与 redis 哨兵一起工作以提供故障转移支持

    Beholder 的目的是在 redis 节点发生故障后扩展 twemproxy 的 HA 功能。 为了实现这一点,beholder 持续监控+switch-master事件,然后它会更新 twemproxy 配置文件并重新启动资源。依赖关系使用和 ,所以第一步是...

    OneCache.pdf

    OneCache中文文档,针对Redis的代理服务,OneCache a Redis protocol based distributed cache middleware, as a replacement of Twemproxy or Codis. Single redis instance is not power enough, so we need groups...

    automake-1.16.2.tar.gz

    使应用程序只需要在Twemproxy上进行操作,而不用关心后面具体有多少个真实的Redis或Memcached存储,有了Twemproxy,客户端不直接访问Redis服务器,而是通过twemproxy 代理中间件间接访问。此包是用于安装redis的...

    乌鸦:Redis 3.0的快速轻量级Redis集群代理

    乌鸦座 Corvus是启用了集群模式的Redis 3.0的快速轻量级Redis集群代理。为什么大多数Redis客户端实现不支持Redis集群。 我们有很多依赖Redis的服务,这些服务是用Python,Java,Go,Nodejs等编写的。在不破坏兼容性...

    运维部-redis服务

    3)采用twemproxy作为代理模式,缺点依赖较多组件,不易于维护,很难平滑的进行扩容,运维代价大。 4)少部分采用redis + sentinel模式,但须配置多个sentinel来检测和切换主从状态,不易水平扩展。 5)重要业务...

    Redis 集群解决方案 Codis.zip

    server)ZooKeepercodis-proxy 是客户端连接的 Redis 代理服务, codis-proxy 本身实现了 Redis 协议, 表现得和一个原生的 Redis 没什么区别 (就像 Twemproxy), 对于一个业务来说, 可以部署多个 codis-proxy, codis-...

    twemproxy:一种用于memcached和redis的快速轻量级代理

    twemproxy (发音为“ two-em-proxy”),又名胡桃夹子,是一种用于和协议的快速轻量级代理。 它的建立主要是为了减少与后端缓存服务器的连接数。 这与协议流水线和分片一起使您能够水平扩展分布式缓存体系结构。 ...

    Codis分布式Redis解决方案-其他

    codis-proxy是客户端连接的Redis代理服务,codis-proxy本身实现了Redis协议,表现得和一个原生的Redis没什么区别(就像Twemproxy),对于一个业务来说,可以部署多个codis-proxy,codis-proxy本身是无状态的。...

    快速,轻量级的代理,用于memcached和Redis-C/C++开发

    twemproxy(胡桃夹子)twemproxy(发音为“ Two-em-proxy”),又名胡桃夹子,是一种用于memcached和redis协议的快速轻量级代理。 它的建立主要是为了减少与twemproxy(nutcracker)twemproxy(发音为“ two-em-...

    Redis面试专题1

    1.twemproxy,大概概念是,它类似于一个代理方式,使用方法和普通 Redis 无任何区别, 2. codis,目前用的最多的集群方案,基本和 twemp

Global site tag (gtag.js) - Google Analytics