开发者社区> 技术小牛人> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

python 实现类似tweproxy 和codes的功能的redis代理功能

简介:
+关注继续查看

手动编写redis代理软件脚本  实现类似tweproxy  和codes的功能

已经实现内容如下:

 起1个代理ip和端口  redisl客户端连接代理  然后脚本通过一致性hash分发key到后端的redis



脚本如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
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)
        = 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:
    = ThreadedTCPServer(('',6379), service)
    t.serve_forever()
except KeyboardInterrupt:
    sys.exit(1)

本文转自   tianshuai369   51CTO博客,原文链接:http://blog.51cto.com/kkkkkk/1760030

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
使用python实现一个文件搜索功能,类似于Everything功能
一般人日常总是会将一些片段信息记录到文件中,放到电脑硬盘上。等过段时间,可能就不知道放到哪里了,电脑上文件夹太多。 找文件一般都会借助于搜索软件,比如Everything软件就很强大,输入名称,就能全局查找文件;
0 0
【Python】300行代码实现crontab定时器功能 【上】
熟悉Linux的都知道在Linux下有一个crontab的定时任务,可以很方便的进行各种定时、计划任务的执行。有时候写代码也需要用到定时器业务,因此我使用Python实现了一个类似的定时器模块,可以很方便的做定时业务,使用例子如下:
0 0
一行Python可以实现的功能
手头有 109 张头部 CT 的断层扫描图片,我打算用这些图片尝试头部的三维重建。基础工作之一,就是要把这些图片数据读出来,组织成一个三维的数据结构(实际上是四维的,因为每个像素有 RGBA 四个通道)。
510 0
Python实现手绘功能
手绘图确实很好看,但对于手残党的我,只能呵呵一笑,今天就用代码来实现手绘功能,把普通的图片转换为手绘图片。 代码 from PIL import Image import numpy as np a = np.
815 0
Python实现简单爬虫功能
Python实现简单爬虫功能
1625 0
Python编程:MySQLdb模块对数据库的基本增删改查操作
Python编程:MySQLdb模块对数据库的基本增删改查操作
0 0
Python编程:entry_points将Python模块转变为命令行工具
Python编程:entry_points将Python模块转变为命令行工具
0 0
Python编程:SQLAlchemy查询数据没有变化
遇到一个问题,使用一条相同的sql,多次查询数据库,每次数据都一样,而且数据库更新了,也没有查到新数据 经过Google,发现是SQLAlchemy的缓存机制导致的 设置隔离级别参数isolation_level 就可以解决
0 0
Python程序设计 实验9:GUI编程
Python程序设计 实验9:GUI编程
0 0
文章
问答
文章排行榜
最热
最新
相关电子书
更多
Redis的开发规范和常见问题
立即下载
Redis&MongoDB的同步、迁移以及混合云场景构建
立即下载
AliSQL性能优化与功能突破的演进之路
立即下载