-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathkv_http.py
83 lines (65 loc) · 2.17 KB
/
kv_http.py
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#!/usr/bin/env python
# -*- coding: utf8 -*-
import sys
import json
import socket
import random
debug = False
from flask import Flask, Response
app = Flask(__name__)
partners = []
leader = None
def handle(req):
global partners, leader
udp_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
udp_socket.settimeout(1)
for i in xrange(3):
try:
udp_socket.sendto(json.dumps(req), leader)
buff, addr = udp_socket.recvfrom(1024)
rsp = json.loads(buff)
if rsp['ret'] == -999:
if debug:
print 'Get Leader %s' % rsp['redirect']
if rsp['redirect']:
leader = tuple(rsp['redirect'])
else:
random.shuffle(partners)
leader = tuple(partners[0])
continue
return rsp
except Exception, e:
if debug:
print 'Err: %s' % e
random.shuffle(partners)
leader = tuple(partners[0])
return {'ret': -9, 'err': 'Timeout'}
@app.route('/')
def usage():
return Response('''Usage:
/<key>/get Get a key
/<key>/set/<val> Set a key by val
/<key>/del Del a key
''', mimetype='text/plain')
@app.route('/<key>/get')
def app_get(key):
return json.dumps(handle({'cmd': 'get', 'key': key}))
@app.route('/<key>/set/<val>')
def app_set(key, val):
return json.dumps(handle({'cmd': 'set', 'key': key, 'val': val}))
@app.route('/<key>/del')
def app_del():
return json.dumps(handle({'cmd': 'del', 'key': key}))
if __name__ == '__main__':
# python kv_http.py 9909 127.0.0.1:9901 127.0.0.1:9902 127.0.0.1:9903
if len(sys.argv) < 5 or '-h' in sys.argv or '--help' in sys.argv:
print 'Usage: python kv_http.py httpPort partner1Host:port partner2Host:port partner3Host:port ...'
sys.exit()
def get_addr_by_str(s):
hps = s.split(':')
return (hps[0], int(hps[1]))
for i in xrange(2, len(sys.argv)):
partners.append(get_addr_by_str(sys.argv[i]))
random.shuffle(partners)
leader = tuple(partners[0])
app.run(host='0.0.0.0', port=int(sys.argv[1]))