-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathqueueMaster.py
executable file
·117 lines (97 loc) · 4 KB
/
queueMaster.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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
#!/usr/bin/env python
import socket
import threading
import SocketServer
import sys
import signal
import mongoConfig as mc
import mongoTools
import singletonObj
queueLock = threading.Lock()
server=""
firstInst=singletonObj.singletonObj()
#SocketServer.BaseRequestHandler
class ThreadedTCPRequestHandler(SocketServer.StreamRequestHandler):
def __init__(self, request, client_address, server):
self.mt = mongoTools.mongoTools(mc.usr,mc.pw,mc.url,mc.port,mc.dbname)
SocketServer.StreamRequestHandler.__init__(self, request, client_address, server)
# http://blog.pythonisito.com/2012/01/getting-started-with-mongodb-and-python.html
def handle(self):
data = self.rfile.readline()
resp = self.manageQueue(data)
self.request.send(resp)
def manageQueue(self, data):
fail=0
x=0
resp=""
links=[]
# TODO: make sure to save which urls linked to where
if "<add|" in data or "<done|" in data:
print "adding items to queue..."
for packet in data.strip("\n").split(">|"):
if len(packet)>0:
bits = packet.strip().strip("<").strip(">").split("|")
if bits[0] == "add":
if bits[2]=="":
print "blank field in bits[2]",bits
else:
res = self.mt.insertQueue(bits[1],int(bits[2]))
if res < 0:
print "issue inserting into database.."
fail+=1
else:
links.append(bits[1])
x+=1
elif bits[0] == "done":
res = self.mt.markDone(bits[1], links)
print bits[1]," marked done."
else:
print "not yet implemented |",packet,"|"
resp = "Items added: %d/%d" % ((x-fail),x)
elif "<request|" in data:
# we are locking here to pass back and forth a singleton
# containing one instance of mongoTools so that when
# we are requesting TODOs, we can iterate over the
# cursor returned to us by the DB without loosing track
# of where we are.
singleMongoTools=singletonObj.singletonObj()
queueLock.acquire()
try:
bits = data.strip('<>\n').split("|")
if bits[0] == "request":
print "processing request.."
resp = singleMongoTools.mt.requestURLs(int(bits[1]))
else:
resp = "malformed packet: ",data
finally:
queueLock.release()
else:
resp = "malformed packet: ",data
return resp
class ThreadedTCPServer(SocketServer.ThreadingMixIn, SocketServer.TCPServer):
pass
def client(ip, port, message):
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect((ip, port))
sock.send(message)
response = sock.recv(1024)
print "Received: %s" % response
sock.close()
# catch signal to gracefully shut down
def signal_handler(signal, frame):
print "shutting down.."
server.shutdown()
sys.exit(0)
if __name__ == "__main__":
# Port 0 means to select an arbitrary unused port
HOST, PORT = "localhost", 65001
server = ThreadedTCPServer((HOST, PORT), ThreadedTCPRequestHandler)
ip, port = server.server_address
# Start a thread with the server -- that thread will then start one
# more thread for each request
server_thread = threading.Thread(target=server.serve_forever)
# set the CTRL+C signal handler to exit gracefully
signal.signal(signal.SIGINT, signal_handler)
server_thread.start()
print "Server loop running in thread:", server_thread.getName()
signal.pause()