forked from GauravJayaraj/dsproject_raft
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.py
84 lines (70 loc) · 2.42 KB
/
server.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
84
from node import Node
from node import FOLLOWER, LEADER
from flask import Flask, request, jsonify
import sys
import logging
app = Flask(__name__)
# value_get is the flask handle
@app.route("/request", methods=['GET'])
def value_get():
payload = request.json["payload"]
reply = {"code": 'fail', 'payload': payload}
if n.status == LEADER:
# request handle, reply is a dictionary
result = n.handle_get(payload)
if result:
reply = {"code": "success", "payload": result}
elif n.status == FOLLOWER:
# redirect request
reply["payload"]["message"] = n.leader
return jsonify(reply)
@app.route("/request", methods=['PUT'])
def value_put():
payload = request.json["payload"]
reply = {"code": 'fail'}
if n.status == LEADER:
# request handle, reply is a dictionary
result = n.handle_put(payload)
if result:
reply = {"code": "success"}
elif n.status == FOLLOWER:
# redirect request
payload["message"] = n.leader
reply["payload"] = payload
return jsonify(reply)
# we reply to vote request
@app.route("/vote_req", methods=['POST'])
def vote_req():
# also need to let me know whether up-to-date or not
term = request.json["term"]
commitIdx = request.json["commitIdx"]
staged = request.json["staged"]
choice, term = n.decide_vote(term, commitIdx, staged)
message = {"choice": choice, "term": term}
return jsonify(message)
@app.route("/heartbeat", methods=['POST'])
def heartbeat():
term, commitIdx = n.heartbeat_follower(request.json)
# return anyway, if nothing received by leader, we are dead
message = {"term": term, "commitIdx": commitIdx}
return jsonify(message)
# disable flask logging
log = logging.getLogger('werkzeug')
log.disabled = True
if __name__ == "__main__":
# python server.py index ip_list
if len(sys.argv) == 3:
index = int(sys.argv[1])
ip_list_file = sys.argv[2]
ip_list = []
# open ip list file and parse all the ips
with open(ip_list_file) as f:
for ip in f:
ip_list.append(ip.strip())
my_ip = ip_list.pop(index)
http, host, port = my_ip.split(':')
# initialize node with ip list and its own ip
n = Node(ip_list, my_ip)
app.run(host="0.0.0.0", port=int(port), debug=False)
else:
print("usage: python server.py <index> <ip_list_file>")