python 实现类似tweproxy 和codes的功能的redis代理功能
2016-04-04 09:20
1081 查看
手动编写redis代理软件脚本 实现类似tweproxy 和codes的功能已经实现内容如下: 起1个代理ip和端口 redisl客户端连接代理 然后脚本通过一致性hash分发key到后端的redis
脚本如下
脚本如下
import SocketServer,sys from threading import Thread import socket from hash_ring import HashRing redis_servers = ['127.0.0.1:6480', '127.0.0.1:6481', '127.0.0.1:6482'] ring = HashRing(redis_servers) class service(SocketServer.BaseRequestHandler): def handle(self): data = 'dummy' print "Client connected with ", self.client_address while len(data): data = self.request.recv(1024) if data: key =(data.split("\n"))[4] server = ring.get_node(key) s = socket.socket(socket.AF_INET,socket.SOCK_STREAM) s.connect(((server.split(":"))[0],int((server.split(":"))[1]))) s.sendall(data) r_data = s.recv(1024) print server self.request.send(r_data) print "Client exited" self.request.close() class ThreadedTCPServer(SocketServer.ThreadingMixIn, SocketServer.TCPServer): pass try: t = ThreadedTCPServer(('',6379), service) t.serve_forever() except KeyboardInterrupt: sys.exit(1)
相关文章推荐
- redis安装问题小结
- 使用 Redis 和 Python 构建一个共享单车的应用程序
- Redis偶发连接失败案例实战记录
- Redis中实现查找某个值的范围
- redis的hGetAll函数的性能问题(记Redis那坑人的HGETALL)
- Redis和Memcached的区别详解
- 分割超大Redis数据库例子
- Redis总结笔记(一):安装和常用命令
- Redis sort 排序命令详解
- 用Redis实现微博关注关系
- redis中修改配置文件中的端口号 密码方法
- 在Ruby on Rails上使用Redis Store的方法
- Redis和Memcache的区别总结
- 在Node.js应用中使用Redis的方法简介
- Redis服务器的启动过程分析
- web 应用中常用的各种 cache详解
- 利用yum安装Redis的方法详解
- 从MySQL到Redis的简单数据库迁移方法
- 为啥懒 Redis 是更好的 Redis
- 利用Redis实现SQL伸缩的方法