summaryrefslogtreecommitdiffstats
path: root/module/web/ServerThread.py
diff options
context:
space:
mode:
authorGravatar RaNaN <Mast3rRaNaN@hotmail.de> 2013-01-18 21:18:29 +0100
committerGravatar RaNaN <Mast3rRaNaN@hotmail.de> 2013-01-18 21:18:29 +0100
commit767692a2acbaf7a33181affcd6fc9c7393184f9b (patch)
treeb36d9e756a0719ba5d711c33846662ee25199c45 /module/web/ServerThread.py
parentevaluate different webservers (diff)
downloadpyload-767692a2acbaf7a33181affcd6fc9c7393184f9b.tar.xz
auto select best webserver
Diffstat (limited to 'module/web/ServerThread.py')
-rw-r--r--module/web/ServerThread.py144
1 files changed, 62 insertions, 82 deletions
diff --git a/module/web/ServerThread.py b/module/web/ServerThread.py
index ffe5ae380..99137b591 100644
--- a/module/web/ServerThread.py
+++ b/module/web/ServerThread.py
@@ -31,15 +31,14 @@ class WebServer(threading.Thread):
self.key = config["ssl"]["key"]
self.host = config['webinterface']['host']
self.port = config['webinterface']['port']
+ self.debug = config['general']['debug_mode']
+ self.force_server = config['webinterface']['force_server']
self.error = None
self.setDaemon(True)
def run(self):
self.running = True
-
- # TODO: clean this up
-
import webinterface
global webinterface
@@ -48,32 +47,20 @@ class WebServer(threading.Thread):
log.warning(_("SSL certificates not found."))
self.https = False
- if self.server == "fastcgi":
- try:
- import flup
- except:
- log.warning(_("Can't use %(server)s, python-flup is not installed!") % {
- "server": self.server})
- self.server = "builtin"
- elif self.server == "lightweight":
- try:
- import bjoern
- except Exception, e:
- log.error(_("Error importing lightweight server: %s") % e)
- log.warning(_("You need to download and compile bjoern, https://github.com/jonashaag/bjoern"))
- log.warning(_("Copy the boern.so to module/lib folder or use setup.py install"))
- log.warning(_("Of course you need to be familiar with linux and know how to compile software"))
- self.server = "builtin"
+ prefer = None
+
+ # These cases covers all settings
+ if self.server == "threaded":
+ prefer = "threaded"
+ elif self.server == "fastcgi":
+ prefer = "flup"
+ elif self.server == "fallback":
+ prefer = "wsgiref"
+
+ server = self.select_server(prefer)
try:
- if self.server == "fastcgi":
- self.start_fcgi()
- elif self.server == "threaded":
- self.start_threaded()
- elif self.server == "fallback":
- self.start_fallback()
- else:
- self.start_auto()
+ self.start_server(server)
except Exception, e:
log.error(_("Failed starting webserver: " + e.message))
@@ -81,72 +68,65 @@ class WebServer(threading.Thread):
if core:
core.print_exc()
- def start_auto(self):
- # TODO: select server
-
-# server = "wsgiref"
-# server = "tornado"
-# server = "fapws3"
-# server = "meinheld"
-# server = "eventlet"
-# server = "bjoern"
- server = "threaded"
-
- if server == "threaded":
- return self.start_threaded()
- if server == "wsgiref":
- return self.start_fallback()
- if server == "bjoern":
- return self.start_lightweight()
- if server == "meinheld":
- def noop(*args, **kwargs):
- pass
- from meinheld import server as sv
- sv.set_access_logger(None)
- sv.set_error_logger(None)
-
- sv.kill_server = noop
-
- log.info("AUTO server %s" % server)
- webinterface.run_server(host=self.host, port=self.port, server=server)
+ def select_server(self, prefer=None):
+ """ find a working server """
+ from servers import all_server
- def start_fallback(self):
- if self.https:
- log.warning(_("This server offers no SSL, please consider using threaded instead"))
+ unavailable = []
+ server = None
+ for server in all_server:
- log.info(_("Starting fallback webserver: %(host)s:%(port)d") % {"host": self.host, "port": self.port})
- webinterface.run_server(host=self.host, port=self.port)
+ if self.force_server and self.force_server == server.NAME:
+ break # Found server
+ # When force_server is set, no further checks have to be made
+ elif self.force_server:
+ continue
- def start_threaded(self):
- if self.https:
- log.info(_("Starting threaded SSL webserver: %(host)s:%(port)d") % {"host": self.host, "port": self.port})
- else:
- self.cert = ""
- self.key = ""
- log.info(_("Starting threaded webserver: %(host)s:%(port)d") % {"host": self.host, "port": self.port})
+ if prefer and prefer == server.NAME:
+ break # found prefered server
+ elif prefer: # prefer is similar to force, but force has precedence
+ continue
- webinterface.run_threaded(host=self.host, port=self.port, cert=self.cert, key=self.key)
+ # Filter for server that offer ssl if needed
+ if self.https and not server.SSL:
+ continue
- def start_fcgi(self):
- from flup.server.threadedserver import ThreadedServer
+ try:
+ if server.find():
+ break # Found a server
+ else:
+ unavailable.append(server.NAME)
+ except Exception, e:
+ log.error(_("Failed importing webserver: " + e.message))
- def noop(*args, **kwargs):
- pass
+ if unavailable: # Just log whats not available to have some debug information
+ log.debug("Unavailable webserver: " + ",".join(unavailable))
- # Monkey patch signal handler, it does not work from threads
- ThreadedServer._installSignalHandlers = noop
+ if not server and self.force_server:
+ server = self.force_server # just return the name
- log.info(_("Starting fastcgi server: %(host)s:%(port)d") % {"host": self.host, "port": self.port})
- webinterface.run_server(host=self.host, port=self.port, server="flup")
+ return server
- def start_lightweight(self):
- if self.https:
- log.warning(_("This server offers no SSL, please consider using threaded instead"))
+ def start_server(self, server):
+
+ from servers import ServerAdapter
+
+ if issubclass(server, ServerAdapter):
+
+ if self.https and not server.SSL:
+ log.warning(_("This server offers no SSL, please consider using threaded instead"))
+
+ # Now instantiate the serverAdapter
+ server = server(self.host, self.port, self.key, self.cert, 6, self.debug) # todo, num_connections
+ name = server.NAME
+
+ else: # server is just a string
+ name = server
+
+ log.info(_("Starting %(name)s webserver: %(host)s:%(port)d") % {"name": name, "host": self.host, "port": self.port})
+ webinterface.run_server(host=self.host, port=self.port, server=server)
- log.info(
- _("Starting lightweight webserver (bjoern): %(host)s:%(port)d") % {"host": self.host, "port": self.port})
- webinterface.run_server(host=self.host, port=self.port, server="bjoern")
# check if an error was raised for n seconds