文档章节

twemproxy 简介

一介码夫_Hum
 一介码夫_Hum
发布于 2015/04/24 19:54
字数 687
阅读 50
收藏 1

twemproxy,也叫nutcraker。是twtter开源的一个redis和memcache代理服务器。 redis作为一个高效的缓存服务器,非常具有应用价值。但是当使用比较多的时候,就希望可以通过某种方式 进行统一管理。避免每个应用每个客户端管理连接的松散性。同时在一定程度上变得可以控制。 搜索了不少的开源代理项目,知乎用python实现的redis分片客户端。用node实现的代理中间层,还有各种Restful的开源代理。

  • RedBrige

    • C + epoll实现的一个小的webserver

    • redis自身执行lua脚本的功能来执行redis命令

    • 访问时在url中带上lua脚本文件的名字,直接调用执行该lua脚本

    • 本质是通过http协议远程执行lua脚本

  • Webdis

    • libevent, http-parser...实现的小型web服务器

    • C 语言实现,通过unix-socket,TCP调用redis命令。

    • 访问方法: /cmd/key/arg0,arg1,... 实质是对redis命令的简单变换

  • redis-proxy

    • 使用node写的redis代理层。

    • 支持主从节点的失败处理(可以仔细研究)

    • 测试后发现性能为原生的1/3

  • twemproxy

    • 连接复用,内存复用。

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

    • 可设置状态监控ip和端口,访问ip和端口可以得到一个json格式的状态信息串

    • 可设置监控信息刷新间隔时间

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

    • 多种hash算法(部分还没有研究明白)

    • 可以设置后端实例的权重

    • 保持与redis的长连接

    • 可设置代理与后台每个redis连接的数目

    • 通过HashTag可以自己设定将两个KEYhash到同一个实例上去。

    • 可以设置重新连接该节点的时间

    • 可以设置连接多少次之后删除该节点

    • 该方式适合作为cache存储

    • 支持失败节点自动删除

    • 支持设置HashTag

    • 减少与redis的直接连接数

    • 自动分片到后端多个redis实例上

    • 避免单点问题

    • 支持redis pipelining request

    • 支持状态监控

    • 高吞吐量

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

    配置部署建议: 编译时候打开logging模块。

    redis部署知识: AOF;一种记录redis写操作的文件,用于恢复redis数据。


    本文转载自:http://cloudaice.com/twemproxy-explore/

    共有 人打赏支持
    一介码夫_Hum
    粉丝 25
    博文 121
    码字总数 29813
    作品 0
    海淀
    其他
    私信 提问
    twemproxy + redis + sentinel 实现redis集群高可用

    本文主要描述使用 twemproxy + redis + sentinel + 脚本 实现redis集群的高可用,篇幅有点长(实战配置文件/命令) 先贴个本文主要标题列表哈 redis简介 sentinel 功能 twemproxy特性 twempr...

    dchuang
    2016/04/27
    2.6K
    0
    比MySQL快60倍 redis从入门到精通视频教程

    Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。 学习视频下载地址:https://pan.baidu.com/s/17NO3pG9hRL-RtU0bwa...

    自学号
    06/02
    0
    0
    Redis异构集群之间数据迁移方案

    一、Redis集群迁移工具 最近在做Redis数据迁移,网上找了两款开源的Redis迁移工具。 第一种:redis-port Codis官方提供的一个工具,redis-port是一个Redis工具,通过解析rdb文件,实现Redis...

    IT--小哥
    10/23
    0
    0
    Redis+Twemproxy做代理部署集群

    redis集群部署过程略。。。 部署Twemproxy 1. yum install autoconf automake libtool -y 2. wget https://github.com/twitter/twemproxy/archive/master.zip 3. unzip master.zip 4.cd twem......

    小白的希望
    06/28
    0
    0
    使用 Twemproxy 来做 SSDB 负载均衡

    Twemproxy 是由 Twitter 公司开发的一个支持 Redis 协议的代理服务器, 可用于 Redis 集群的负载均衡, 高可用性等. SSDB 数据库也支持 Redis 协议, 所以可以直接使用 Twemproxy 而不需要做任何...

    ideawu
    2014/07/29
    1K
    0

    没有更多内容

    加载失败,请刷新页面

    加载更多

    node.js学习笔记之koa框架和简单爬虫练习

    Koa -- 基于 Node.js 平台的下一代 web 开发框架 koa是由 Express 原班人马打造的,致力于成为一个更小、更富有表现力、更健壮的 Web 框架。 使用 koa 编写 web 应用,可以免除重复繁琐的回调...

    前端小攻略
    6分钟前
    0
    0
    JavaScript中的继承及实现代码

    JS虽然不像是JAVA那种强类型的语言,但也有着与JAVA类型的继承属性,那么JS中的继承是如何实现的呢? 一、构造函数继承 在构造函数中,同样属于两个新创建的函数,也是不相等的 function Fn...

    peakedness丶
    28分钟前
    1
    0
    记一次面试最常见的10个Redis"刁难"问题

    导读:在程序员面试过程中Redis相关的知识是常被问到的话题。作为一名在互联网技术行业打击过成百上千名的资深技术面试官,本文作者总结了面试过程中经常问到的问题。十分值得一读。 Redis在...

    小刀爱编程
    41分钟前
    14
    0
    TiDB Lab 诞生记 | TiDB Hackathon 优秀项目分享

    本文由红凤凰粉凤凰粉红凤凰队的成员主笔,他们的项目 TiDB Lab 在本届 TiDB Hackathon 2018 中获得了二等奖。TiDB Lab 为 TiDB 培训体系增加了一个可以动态观测 TiDB / TiKV / PD 细节的动画...

    TiDB
    54分钟前
    4
    0
    当区块链遇到零知识证明

    本文由云+社区发表 当区块链遇到零知识证明 什么是零知识证明 零知识证明的官方定义是能够在不向验证者任何有用的信息的情况下,使验证者相信某个论断是正确的。这个定义有点抽象,下面笔者举...

    腾讯云加社区
    今天
    5
    0

    没有更多内容

    加载失败,请刷新页面

    加载更多

    返回顶部
    顶部