Redis分布式中间件TwemProxy
2016-07-06 15:19
459 查看
twemproxy,也叫nutcraker。是一个twtter开源的一个redis和memcache代理服务器。 redis作为一个高效的缓存服务器,非常具有应用价值。但是当使用比较多的时候,就希望可以通过某种方式 统一进行管理。避免每个应用每个客户端管理连接的松散性。同时在一定程度上变得可以控制。 搜索了不少的开源代理项目,知乎实现的python分片客户端。node的代理中间层,还有各种restfull的开源代理。
RedBrige
C + epoll实现的一个小的webserver
redis自身执行lua脚本的功能来执行redis命令
访问时在url中带上lua脚本文件的名字,直接调用执行该lua脚本
本质是通过http协议远程执行lua脚本
Webdis
libevent, http-parser...实现的小型web服务器
C 语言实现,通过unix-socket,TCP调用redis命令。
访问方法:
redis-proxy
使用node写的redis代理层。
支持主从节点的失败处理(可以仔细研究)
测试后发现性能为原生的1/3
twemproxy
支持失败节点自动删除
可以设置重新连接该节点的时间
可以设置连接多少次之后删除该节点
该方式适合作为cache存储
支持设置HashTag
通过HashTag可以自己设定将两个KEYhash到同一个实例上去。
减少与redis的直接连接数
保持与redis的长连接
可设置代理与后台每个redis连接的数目
自动分片到后端多个redis实例上
多种hash算法(部分还没有研究明白)
可以设置后端实例的权重
避免单点问题
可以平行部署多个代理层.client自动选择可用的一个
支持redis pipelining request
支持状态监控
可设置状态监控ip和端口,访问ip和端口可以得到一个json格式的状态信息串
可设置监控信息刷新间隔时间
高吞吐量
连接复用,内存复用。
将多个连接请求,组成reids pipelining统一向redis请求。
另外可以修改redis的源代码,抽取出redis中的前半部分,作为一个中间代理层。最终都是通过linux下的epoll 事件机制提高并发效率,其中nutcraker本身也是使用epoll的事件机制。并且在性能测试上的表现非常出色。
配置部署建议: 编译时候打开logging模块。
redis部署知识: AOF;一种记录redis写操作的文件,用于恢复redis数据。
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
支持失败节点自动删除
可以设置重新连接该节点的时间
可以设置连接多少次之后删除该节点
该方式适合作为cache存储
支持设置HashTag
通过HashTag可以自己设定将两个KEYhash到同一个实例上去。
减少与redis的直接连接数
保持与redis的长连接
可设置代理与后台每个redis连接的数目
自动分片到后端多个redis实例上
多种hash算法(部分还没有研究明白)
可以设置后端实例的权重
避免单点问题
可以平行部署多个代理层.client自动选择可用的一个
支持redis pipelining request
支持状态监控
可设置状态监控ip和端口,访问ip和端口可以得到一个json格式的状态信息串
可设置监控信息刷新间隔时间
高吞吐量
连接复用,内存复用。
将多个连接请求,组成reids pipelining统一向redis请求。
另外可以修改redis的源代码,抽取出redis中的前半部分,作为一个中间代理层。最终都是通过linux下的epoll 事件机制提高并发效率,其中nutcraker本身也是使用epoll的事件机制。并且在性能测试上的表现非常出色。
配置部署建议: 编译时候打开logging模块。
redis部署知识: AOF;一种记录redis写操作的文件,用于恢复redis数据。
相关文章推荐
- 利用JAVA操作Redis
- Redis配置文件说明
- Redis使用总结
- Redis 认识的几个误区
- centos7 安装部署redis-3.2.1
- 0140 redis实现访问频次限制的几种方式
- linux下redis安装
- 【高并发简单解决方案】redis队列缓存 + mysql 批量入库 + php离线整合 PHP解决抢购、秒杀
- spring与redis集成之aop整合方案
- redis集群部署配置
- linux系统redis服务配置
- redis
- java redis 基本操作
- 0139 Nginx+Lua+Redis 对请求进行限制
- Redis能干啥?细看11种Web应用场景
- REDIS 在电商中的实际应用场景
- Redis初步认识
- redis编译错误解决
- Redis Service
- redis启用持久化