diff options
-rw-r--r-- | module/web/ServerThread.py | 40 | ||||
-rw-r--r-- | module/web/run_fcgi.py | 172 | ||||
-rwxr-xr-x | module/web/run_server.py | 27 | ||||
-rwxr-xr-x | pyLoadCore.py | 2 |
4 files changed, 213 insertions, 28 deletions
diff --git a/module/web/ServerThread.py b/module/web/ServerThread.py index 718dd6136..aa1f67244 100644 --- a/module/web/ServerThread.py +++ b/module/web/ServerThread.py @@ -8,6 +8,7 @@ from subprocess import call from sys import version_info from cStringIO import StringIO import threading +import sys class WebServer(threading.Thread): def __init__(self, pycore): @@ -17,8 +18,9 @@ class WebServer(threading.Thread): self.server = pycore.config['webinterface']['server'] self.https = pycore.config['webinterface']['https'] self.setDaemon(True) - + def run(self): + sys.path.append(join(self.pycore.path, "module", "web")) avail = ["builtin"] host = self.pycore.config['webinterface']['host'] port = self.pycore.config['webinterface']['port'] @@ -90,7 +92,7 @@ class WebServer(threading.Thread): content = content.replace("%(path)", join(path, "servers")) content = content.replace("%(host)", host) - content = content.replace("%(port)", port) + content = content.replace("%(port)", str(port)) content = content.replace("%(media)", join(path, "media")) content = content.replace("%(version)", ".".join(map(str, version_info[0:2]))) @@ -107,11 +109,11 @@ class WebServer(threading.Thread): new_config.write(content) new_config.close() - command = ['python', join(self.pycore.path, "module", "web", "manage.py"), "runfcgi", "daemonize=false", "method=threaded", "host=127.0.0.1", "port=9295"] - self.p = Popen(command, stderr=Output(out), stdin=PIPE, stdout=Output(out)) + command = ['nginx', '-c', join(path, "servers", "nginx.conf"),] + self.p = Popen(command, stderr=PIPE, stdin=PIPE, stdout=Output(out)) - command2 = ['nginx', '-c', join(path, "servers", "nginx.conf"),] - self.p2 = Popen(command2, stderr=PIPE, stdin=PIPE, stdout=Output(out)) + import run_fcgi + run_fcgi.handle("daemonize=false", "method=threaded", "host=127.0.0.1", "port=9295") elif self.server == "lighttpd": @@ -123,7 +125,7 @@ class WebServer(threading.Thread): content = content.replace("%(path)", join(path, "servers")) content = content.replace("%(host)", host) - content = content.replace("%(port)", port) + content = content.replace("%(port)", str(port)) content = content.replace("%(media)", join(path, "media")) content = content.replace("%(version)", ".".join(map(str, version_info[0:2]))) @@ -139,33 +141,35 @@ class WebServer(threading.Thread): new_config.write(content) new_config.close() - command = ['python', join(self.pycore.path, "module", "web", "manage.py"), "runfcgi", "daemonize=false", "method=threaded", "host=127.0.0.1", "port=9295"] - self.p = Popen(command, stderr=Output(out), stdin=PIPE, stdout=Output(out)) + command = ['lighttpd', '-D', '-f', join(path, "servers", "lighttpd.conf")] + self.p = Popen(command, stderr=PIPE, stdin=PIPE, stdout=Output(out)) - command2 = ['lighttpd', '-D', '-f', join(path, "servers", "lighttpd.conf")] - self.p2 = Popen(command2, stderr=PIPE, stdin=PIPE, stdout=Output(out)) + import run_fcgi + run_fcgi.handle("daemonize=false", "method=threaded", "host=127.0.0.1", "port=9295") elif self.server == "builtin": self.pycore.logger.info("Starting django builtin Webserver: %s:%s" % (host, port)) - - command = ['python', join(self.pycore.path, "module", "web", "run_server.py"), "%s:%s" % (host, port)] - self.p = Popen(command, stderr=Output(out), stdin=Output(out), stdout=Output(out)) + + import run_server + run_server.handle(host, port) + #command = ['python', join(self.pycore.path, "module", "web", "run_server.py"), "%s:%s" % (host, port)] + #self.p = Popen(command, stderr=Output(out), stdin=Output(out), stdout=Output(out)) else: #run fastcgi on port - command = ['python', join(self.pycore.path, "module", "web", "manage.py"), "runfcgi", "daemonize=false", "method=threaded", "host=127.0.0.1", "port=%s" % port] - self.p = Popen(command, stderr=Output(out), stdin=PIPE, stdout=Output(out)) + import run_fcgi + run_fcgi.handle("daemonize=false", "method=threaded", "host=127.0.0.1", "port=%s" % str(port)) def quit(self): try: if self.server == "lighttpd" or self.server == "nginx": self.p.kill() - self.p2.kill() + #self.p2.kill() return True else: - self.p.kill() + #self.p.kill() return True except: pass diff --git a/module/web/run_fcgi.py b/module/web/run_fcgi.py new file mode 100644 index 000000000..ce182f158 --- /dev/null +++ b/module/web/run_fcgi.py @@ -0,0 +1,172 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +import os +import sys + +from django.utils import importlib +from flup.server.fcgi import WSGIServer +from flup.server.fcgi_base import BaseFCGIServer +from flup.server.fcgi_base import FCGI_RESPONDER +from flup.server.threadedserver import ThreadedServer + + +os.environ["DJANGO_SETTINGS_MODULE"] = 'settings' + +def handle(*args, **options): + from django.conf import settings + from django.utils import translation + # Activate the current language, because it won't get activated later. + try: + translation.activate(settings.LANGUAGE_CODE) + except AttributeError: + pass + #from django.core.servers.fastcgi import runfastcgi + runfastcgi(args) + + +FASTCGI_OPTIONS = { + 'protocol': 'fcgi', + 'host': None, + 'port': None, + 'socket': None, + 'method': 'fork', + 'daemonize': None, + 'workdir': '/', + 'pidfile': None, + 'maxspare': 5, + 'minspare': 2, + 'maxchildren': 50, + 'maxrequests': 0, + 'debug': None, + 'outlog': None, + 'errlog': None, + 'umask': None, +} + + +def runfastcgi(argset=[], **kwargs): + options = FASTCGI_OPTIONS.copy() + options.update(kwargs) + for x in argset: + if "=" in x: + k, v = x.split('=', 1) + else: + k, v = x, True + options[k.lower()] = v + + try: + import flup + except ImportError, e: + print >> sys.stderr, "ERROR: %s" % e + print >> sys.stderr, " Unable to load the flup package. In order to run django" + print >> sys.stderr, " as a FastCGI application, you will need to get flup from" + print >> sys.stderr, " http://www.saddi.com/software/flup/ If you've already" + print >> sys.stderr, " installed flup, then make sure you have it in your PYTHONPATH." + return False + + flup_module = 'server.' + options['protocol'] + + if options['method'] in ('prefork', 'fork'): + wsgi_opts = { + 'maxSpare': int(options["maxspare"]), + 'minSpare': int(options["minspare"]), + 'maxChildren': int(options["maxchildren"]), + 'maxRequests': int(options["maxrequests"]), + } + flup_module += '_fork' + elif options['method'] in ('thread', 'threaded'): + wsgi_opts = { + 'maxSpare': int(options["maxspare"]), + 'minSpare': int(options["minspare"]), + 'maxThreads': int(options["maxchildren"]), + } + else: + print "ERROR: Implementation must be one of prefork or thread." + + wsgi_opts['debug'] = options['debug'] is not None + + #try: + # module = importlib.import_module('.%s' % flup_module, 'flup') + # WSGIServer = module.WSGIServer + #except: + # print "Can't import flup." + flup_module + # return False + + # Prep up and go + from django.core.handlers.wsgi import WSGIHandler + + if options["host"] and options["port"] and not options["socket"]: + wsgi_opts['bindAddress'] = (options["host"], int(options["port"])) + elif options["socket"] and not options["host"] and not options["port"]: + wsgi_opts['bindAddress'] = options["socket"] + elif not options["socket"] and not options["host"] and not options["port"]: + wsgi_opts['bindAddress'] = None + else: + return fastcgi_help("Invalid combination of host, port, socket.") + + daemon_kwargs = {} + if options['outlog']: + daemon_kwargs['out_log'] = options['outlog'] + if options['errlog']: + daemon_kwargs['err_log'] = options['errlog'] + if options['umask']: + daemon_kwargs['umask'] = int(options['umask']) + + ownWSGIServer(WSGIHandler(), **wsgi_opts).run() + +class ownThreadedServer(ThreadedServer): + def _installSignalHandlers(self): + return + + def _restoreSignalHandlers(self): + return + + +class ownWSGIServer(BaseFCGIServer, ownThreadedServer): + + def __init__(self, application, environ=None, + multithreaded=True, multiprocess=False, + bindAddress=None, umask=None, multiplexed=False, + debug=True, roles=(FCGI_RESPONDER,), forceCGI=False, **kw): + BaseFCGIServer.__init__(self, application, + environ=environ, + multithreaded=multithreaded, + multiprocess=multiprocess, + bindAddress=bindAddress, + umask=umask, + multiplexed=multiplexed, + debug=debug, + roles=roles, + forceCGI=forceCGI) + for key in ('jobClass', 'jobArgs'): + if kw.has_key(key): + del kw[key] + ownThreadedServer.__init__(self, jobClass=self._connectionClass, + jobArgs=(self,), **kw) + + def _isClientAllowed(self, addr): + return self._web_server_addrs is None or \ + (len(addr) == 2 and addr[0] in self._web_server_addrs) + + def run(self): + """ + The main loop. Exits on SIGHUP, SIGINT, SIGTERM. Returns True if + SIGHUP was received, False otherwise. + """ + self._web_server_addrs = os.environ.get('FCGI_WEB_SERVER_ADDRS') + if self._web_server_addrs is not None: + self._web_server_addrs = map(lambda x: x.strip(), + self._web_server_addrs.split(',')) + + sock = self._setupSocket() + + ret = ownThreadedServer.run(self, sock) + + self._cleanupSocket(sock) + + return ret + +if __name__ == "__main__": + handle(*sys.argv[1:]) + diff --git a/module/web/run_server.py b/module/web/run_server.py index 5ffa45781..6aa8bdba4 100755 --- a/module/web/run_server.py +++ b/module/web/run_server.py @@ -2,6 +2,9 @@ # -*- coding: utf-8 -*- import os import sys +import django +from django.core.servers.basehttp import AdminMediaHandler, WSGIServerException, WSGIServer, WSGIRequestHandler +from django.core.handlers.wsgi import WSGIHandler os.environ["DJANGO_SETTINGS_MODULE"] = 'settings' @@ -15,14 +18,10 @@ class Output: def __getattr__(self, attr): return getattr(self.stream, attr) -sys.stderr = Output(sys.stderr) +#sys.stderr = Output(sys.stderr) #sys.stdout = Output(sys.stdout) def handle(* args): - import django - from django.core.servers.basehttp import run, AdminMediaHandler, WSGIServerException - from django.core.handlers.wsgi import WSGIHandler - try: if len(args) == 1: try: @@ -37,7 +36,7 @@ def handle(* args): addr = '127.0.0.1' port = '8000' - print addr, port + #print addr, port admin_media_path = '' shutdown_message = '' @@ -46,9 +45,9 @@ def handle(* args): from django.conf import settings from django.utils import translation - print "\nDjango version %s, using settings %r" % (django.get_version(), settings.SETTINGS_MODULE) + print "Django version %s, using settings %r" % (django.get_version(), settings.SETTINGS_MODULE) print "Development server is running at http://%s:%s/" % (addr, port) - print "Quit the server with %s." % quit_command + #print "Quit the server with %s." % quit_command translation.activate(settings.LANGUAGE_CODE) @@ -74,7 +73,17 @@ def handle(* args): if shutdown_message: print shutdown_message sys.exit(0) - + +class ownRequestHandler(WSGIRequestHandler): + def log_message(self, format, *args): + return + + +def run(addr, port, wsgi_handler): + server_address = (addr, port) + httpd = WSGIServer(server_address, ownRequestHandler) + httpd.set_app(wsgi_handler) + httpd.serve_forever() if __name__ == "__main__": handle(*sys.argv[1:]) diff --git a/pyLoadCore.py b/pyLoadCore.py index 643156d25..862c39da1 100755 --- a/pyLoadCore.py +++ b/pyLoadCore.py @@ -424,7 +424,7 @@ class Core(object): try: if self.config['webinterface']['activated']: self.webserver.quit() - self.webserver.join() + #self.webserver.join() for thread in self.thread_list.threads: thread.shutdown = True self.thread_list.stopAllDownloads() |