gyorgyf@0
|
1 #!/usr/bin/env python
|
gyorgyf@0
|
2 # encoding: utf-8
|
gyorgyf@0
|
3 """
|
gyorgyf@0
|
4 mcserver.py
|
gyorgyf@0
|
5
|
gyorgyf@0
|
6 Created by George Fazekas on 2012-06-16.
|
gyorgyf@0
|
7 Copyright (c) 2012 . All rights reserved.
|
gyorgyf@0
|
8 """
|
gyorgyf@0
|
9
|
gyorgyf@0
|
10 import os,sys,optparse,signal
|
gyorgyf@0
|
11 import cherrypy as cp
|
gyorgyf@0
|
12
|
gyorgyf@0
|
13 from cherrypy.lib import static
|
gyorgyf@0
|
14 import subprocess as sp
|
gyorgyf@0
|
15 from subprocess import Popen as spopen
|
gyorgyf@0
|
16
|
gyorgyf@0
|
17
|
gyorgyf@0
|
18 op = optparse.OptionParser()
|
gyorgyf@0
|
19 op.add_option('-u', '--user', action="store", dest="USER", default="server", type="str")
|
gyorgyf@0
|
20 options, args = op.parse_args()
|
gyorgyf@0
|
21 CONFIG_FILE = "mc%(USER)s.cfg" %options.__dict__
|
gyorgyf@0
|
22
|
gyorgyf@0
|
23 if not os.path.isfile(CONFIG_FILE) :
|
gyorgyf@4
|
24 print >> sys.stderr, "Config file not found: %s" %CONFIG_FILE
|
gyorgyf@0
|
25 sys.exit(-1)
|
gyorgyf@0
|
26
|
gyorgyf@0
|
27
|
gyorgyf@0
|
28 class MoodConductor:
|
gyorgyf@0
|
29
|
gyorgyf@0
|
30 def index(self):
|
gyorgyf@4
|
31 return ""
|
gyorgyf@0
|
32
|
gyorgyf@0
|
33 @cp.expose
|
gyorgyf@0
|
34 def mood(self,x,y):
|
gyorgyf@0
|
35 print x,y
|
gyorgyf@0
|
36 return "OK"
|
gyorgyf@0
|
37
|
gyorgyf@0
|
38
|
gyorgyf@0
|
39
|
gyorgyf@0
|
40 def getProcessPids(port,kill=False):
|
gyorgyf@0
|
41 '''Get the pid of the offending Python process given a port after an unsuccessful restart.'''
|
gyorgyf@0
|
42 print "Running lsof -i :"+str(port)," ...\n\n"
|
gyorgyf@0
|
43 command = "lsof -i :"+str(port)
|
gyorgyf@0
|
44 w = spopen(command,stdout=sp.PIPE,stderr=sp.PIPE,shell=True)
|
gyorgyf@0
|
45 se = w.stderr.readlines()
|
gyorgyf@0
|
46 result = w.stdout.readlines()
|
gyorgyf@0
|
47 exitcode = w.wait()
|
gyorgyf@0
|
48 if not result :
|
gyorgyf@0
|
49 print "getProcessPid:: Unable to obtain process pid. (lsof returned nothing. exitcode: %s)" %str(exitcode)
|
gyorgyf@0
|
50 return False
|
gyorgyf@0
|
51 import pprint
|
gyorgyf@0
|
52 pprint.pprint(result)
|
gyorgyf@0
|
53
|
gyorgyf@0
|
54 # get heading:
|
gyorgyf@0
|
55 ix = None
|
gyorgyf@0
|
56 head = result[0].upper()
|
gyorgyf@0
|
57 if 'PID' in head:
|
gyorgyf@0
|
58 head = filter(lambda x: x != str(), head.split(' '))
|
gyorgyf@0
|
59 head = map(lambda x: x.strip().replace(' ',''), head)
|
gyorgyf@0
|
60 if 'PID' in head : ix = head.index('PID')
|
gyorgyf@0
|
61 # get process pid
|
gyorgyf@0
|
62 pids = []
|
gyorgyf@0
|
63 for line in result :
|
gyorgyf@0
|
64 if 'python' in line.lower() :
|
gyorgyf@0
|
65 line = filter(lambda x: x != str(), line.split(' '))
|
gyorgyf@0
|
66 line = map(lambda x: x.strip().replace(' ',''), line)
|
gyorgyf@0
|
67 try :
|
gyorgyf@0
|
68 if ix :
|
gyorgyf@0
|
69 pids.append(int(line[ix]))
|
gyorgyf@0
|
70 else:
|
gyorgyf@0
|
71 numbers = filter(lambda x: x.isdigit(), line)
|
gyorgyf@0
|
72 pids.append(int(numbers[0]))
|
gyorgyf@0
|
73 except:
|
gyorgyf@0
|
74 print 'Error parsing lsof results.'
|
gyorgyf@0
|
75 return False
|
gyorgyf@0
|
76 print 'Pids found: ',pids
|
gyorgyf@0
|
77 # kill if specified
|
gyorgyf@0
|
78 if kill :
|
gyorgyf@0
|
79 pids_killed = []
|
gyorgyf@0
|
80 import signal
|
gyorgyf@0
|
81 for pid in pids:
|
gyorgyf@0
|
82 print 'Killing process: ',pid
|
gyorgyf@0
|
83 try :
|
gyorgyf@0
|
84 os.kill(pid,signal.SIGKILL)
|
gyorgyf@0
|
85 pids_killed.append(pid)
|
gyorgyf@0
|
86 except :
|
gyorgyf@0
|
87 print 'Failed: ',pid
|
gyorgyf@0
|
88 if pids_killed :
|
gyorgyf@0
|
89 print 'Processes killed:',pids_killed,' Waiting 10 secods...'
|
gyorgyf@0
|
90 import time
|
gyorgyf@0
|
91 time.sleep(10)
|
gyorgyf@0
|
92 return True
|
gyorgyf@0
|
93 return False
|
gyorgyf@0
|
94
|
gyorgyf@0
|
95
|
gyorgyf@0
|
96 def main(argv=None):
|
gyorgyf@0
|
97
|
gyorgyf@0
|
98 # Configure and start
|
gyorgyf@3
|
99 cp.config.update(CONFIG_FILE)
|
gyorgyf@0
|
100 cp.config.update({'tools.staticdir.root': os.getcwd()})
|
gyorgyf@3
|
101 cp.tree.mount(MoodConductor(),script_name="/moodconductor",config=CONFIG_FILE)
|
gyorgyf@2
|
102 port = int(cp.server.socket_port)
|
gyorgyf@3
|
103 ip = cp.server.socket_host
|
gyorgyf@3
|
104 print "Trying to bind: %(ip)s:%(port)s" %locals()
|
gyorgyf@0
|
105 getProcessPids(port,kill=True)
|
gyorgyf@0
|
106 cp.quickstart()
|
gyorgyf@0
|
107
|
gyorgyf@0
|
108 if __name__ == "__main__":
|
gyorgyf@0
|
109 main()
|