diff options
author | RaNaN <Mast3rRaNaN@hotmail.de> | 2010-08-27 22:44:01 +0200 |
---|---|---|
committer | RaNaN <Mast3rRaNaN@hotmail.de> | 2010-08-27 22:44:01 +0200 |
commit | f31082dfaf52c80b3f7ee96ef4390af2d1e9331c (patch) | |
tree | d391670f160b5733c218581a0311587710b201a9 /module | |
parent | readded speedmanager (diff) | |
download | pyload-f31082dfaf52c80b3f7ee96ef4390af2d1e9331c.tar.xz |
implemented speedmanager
Diffstat (limited to 'module')
-rw-r--r-- | module/HookManager.py | 2 | ||||
-rw-r--r-- | module/PluginThread.py | 1 | ||||
-rw-r--r-- | module/SpeedManager.py | 71 | ||||
-rw-r--r-- | module/config/default.conf | 1 |
4 files changed, 39 insertions, 36 deletions
diff --git a/module/HookManager.py b/module/HookManager.py index 8a6193d87..8bb8d1d5b 100644 --- a/module/HookManager.py +++ b/module/HookManager.py @@ -48,6 +48,7 @@ class HookManager(): return func(*args) except Exception, e: args[0].log.error(_("Error executing hooks: %s") % str(e)) + traceback.print_exc() return new def createIndex(self): @@ -58,7 +59,6 @@ class HookManager(): #hookClass = getattr(plugin, plugin.__name__) if self.core.config.getPlugin(pluginClass.__name__, "load"): - #@TODO handle in pluginmanager plugin = pluginClass(self.core) plugins.append(plugin) self.log.info(_("%(name)s loaded, activated %(value)s") % {"name": pluginClass.__name__, "value": plugin.isActivated() }) diff --git a/module/PluginThread.py b/module/PluginThread.py index 9d16155ef..32426766a 100644 --- a/module/PluginThread.py +++ b/module/PluginThread.py @@ -147,7 +147,6 @@ class DownloadThread(PluginThread): except Reconnect: self.queue.put(pyfile) - #@TODO #pyfile.req.clearCookies() while self.m.reconnecting.isSet(): diff --git a/module/SpeedManager.py b/module/SpeedManager.py index e69c641fc..e0ce05586 100644 --- a/module/SpeedManager.py +++ b/module/SpeedManager.py @@ -23,44 +23,49 @@ from threading import Thread from time import sleep, time class SpeedManager(Thread): - def __init__(self, parent): + def __init__(self, core, hook): Thread.__init__(self) - self.parent = parent + self.setDaemon(True) + + self.hook = hook + self.core = core self.running = True self.lastSlowCheck = 0.0 - + stat = {} stat["slow_downloads"] = None stat["each_speed"] = None stat["each_speed_optimized"] = None self.stat = stat - + self.slowCheckInterval = 60 self.slowCheckTestTime = 25 - - self.logger = self.parent.parent.logger + + self.log = self.core.log self.start() - + def run(self): while self.running: sleep(1) self.manageSpeed() - + def getMaxSpeed(self): - return self.parent.parent.getMaxSpeed() - + return int(self.hook.getConfig("speed")) + def manageSpeed(self): maxSpeed = self.getMaxSpeed() - if maxSpeed <= 0: - for thread in self.parent.py_downloading: - thread.plugin.req.speedLimitActive = False + if maxSpeed <= 0 or self.core.compare_time(self.hook.getConfig("start").split(":"), + self.hook.getConfig("end").split(":")): + for pyfile in [x.active for x in self.core.threadManager.threads if x.active and x.active != "quit"]: + pyfile.plugin.req.speedLimitActive = False return - threads = self.parent.py_downloading + + threads = [x.active for x in self.core.threadManager.threads if x.active and x.active != "quit"] threadCount = len(threads) - if threadCount <= 0: + if not threads: return - eachSpeed = maxSpeed/threadCount - + eachSpeed = maxSpeed / threadCount + currentOverallSpeed = 0 restSpeed = maxSpeed - currentOverallSpeed speeds = [] @@ -68,39 +73,39 @@ class SpeedManager(Thread): currentOverallSpeed += thread.plugin.req.dl_speed speeds.append((thread.plugin.req.dl_speed, thread.plugin.req.averageSpeed, thread)) thread.plugin.req.speedLimitActive = True - - if currentOverallSpeed+50 < maxSpeed: - for thread in self.parent.py_downloading: + + if currentOverallSpeed + 50 < maxSpeed: + for thread in threads: thread.plugin.req.speedLimitActive = False return - + slowCount = 0 slowSpeed = 0 - if self.lastSlowCheck + self.slowCheckInterval + self.slowCheckTestTime < time.time(): - self.lastSlowCheck = time.time() - if self.lastSlowCheck + self.slowCheckInterval < time.time() < self.lastSlowCheck + self.slowCheckInterval + self.slowCheckTestTime: + if self.lastSlowCheck + self.slowCheckInterval + self.slowCheckTestTime < time(): + self.lastSlowCheck = time() + if self.lastSlowCheck + self.slowCheckInterval < time( + ) < self.lastSlowCheck + self.slowCheckInterval + self.slowCheckTestTime: for speed in speeds: speed[2].plugin.req.isSlow = False else: for speed in speeds: - if speed[0] <= eachSpeed-7: - if speed[1] < eachSpeed-15: - if speed[2].plugin.req.dl_time > 0 and speed[2].plugin.req.dl_time+30 < time.time(): + if speed[0] <= eachSpeed - 7: + if speed[1] < eachSpeed - 15: + if speed[2].plugin.req.dl_time > 0 and speed[2].plugin.req.dl_time + 30 < time(): speed[2].plugin.req.isSlow = True - if not speed[1]-5 < speed[2].plugin.req.maxSpeed/1024 < speed[1]+5: - speed[2].plugin.req.maxSpeed = (speed[1]+10)*1024 + if not speed[1] - 5 < speed[2].plugin.req.maxSpeed / 1024 < speed[1] + 5: + speed[2].plugin.req.maxSpeed = (speed[1] + 10) * 1024 if speed[2].plugin.req.isSlow: slowCount += 1 - slowSpeed += speed[2].plugin.req.maxSpeed/1024 + slowSpeed += speed[2].plugin.req.maxSpeed / 1024 stat = {} stat["slow_downloads"] = slowCount stat["each_speed"] = eachSpeed eachSpeed = (maxSpeed - slowSpeed) / (threadCount - slowCount) stat["each_speed_optimized"] = eachSpeed self.stat = stat - + for speed in speeds: if speed[2].plugin.req.isSlow: continue - speed[2].plugin.req.maxSpeed = eachSpeed*1024 - print "max", speed[2].plugin.req.maxSpeed, "current", speed[2].plugin.req.dl_speed + speed[2].plugin.req.maxSpeed = eachSpeed * 1024 diff --git a/module/config/default.conf b/module/config/default.conf index df8682804..915604084 100644 --- a/module/config/default.conf +++ b/module/config/default.conf @@ -26,7 +26,6 @@ general - "General": int max_downloads : "Max Parallel Downloads" = 3
bool debug_mode : "Debug Mode" = False
int max_download_time : "Max Download Time" = 5
- int download_speed_limit : "Download Speed Limit" = 0
bool checksum : "Use Checksum" = False
int min_free_space : "Min Free Space (MB)" = 200
bool folder_per_package : "Create folder for each package" = True
|