Browse Source

Rework restart methods

pull/3341/head
Ruud 11 years ago
parent
commit
94064ac7da
  1. 6
      CouchPotato.py
  2. 8
      couchpotato/core/_base/_core.py
  3. 4
      couchpotato/core/_base/scheduler.py
  4. 4
      couchpotato/core/_base/updater/main.py
  5. 2
      couchpotato/core/plugins/base.py
  6. 9
      couchpotato/runner.py
  7. 11
      couchpotato/static/scripts/couchpotato.js

6
CouchPotato.py

@ -72,10 +72,11 @@ class Loader(object):
signal.signal(signal.SIGTERM, lambda signum, stack_frame: sys.exit(1)) signal.signal(signal.SIGTERM, lambda signum, stack_frame: sys.exit(1))
from couchpotato.core.event import addEvent from couchpotato.core.event import addEvent
addEvent('app.after_shutdown', self.afterShutdown) addEvent('app.do_shutdown', self.setRestart)
def afterShutdown(self, restart): def setRestart(self, restart):
self.do_restart = restart self.do_restart = restart
return True
def onExit(self, signal, frame): def onExit(self, signal, frame):
from couchpotato.core.event import fireEvent from couchpotato.core.event import fireEvent
@ -103,7 +104,6 @@ class Loader(object):
# Release log files and shutdown logger # Release log files and shutdown logger
logging.shutdown() logging.shutdown()
time.sleep(3)
args = [sys.executable] + [os.path.join(base_path, os.path.basename(__file__))] + sys.argv[1:] args = [sys.executable] + [os.path.join(base_path, os.path.basename(__file__))] + sys.argv[1:]
subprocess.Popen(args) subprocess.Popen(args)

8
couchpotato/core/_base/_core.py

@ -118,7 +118,7 @@ class Core(Plugin):
self.shutdown_started = True self.shutdown_started = True
fireEvent('app.do_shutdown') fireEvent('app.do_shutdown', restart = restart)
log.debug('Every plugin got shutdown event') log.debug('Every plugin got shutdown event')
loop = True loop = True
@ -143,9 +143,11 @@ class Core(Plugin):
log.debug('Safe to shutdown/restart') log.debug('Safe to shutdown/restart')
loop = IOLoop.current()
try: try:
if not IOLoop.current()._closing: if not loop._closing:
IOLoop.current().stop() loop.stop()
except RuntimeError: except RuntimeError:
pass pass
except: except:

4
couchpotato/core/_base/scheduler.py

@ -33,9 +33,9 @@ class Scheduler(Plugin):
except: except:
pass pass
def doShutdown(self): def doShutdown(self, *args, **kwargs):
self.stop() self.stop()
return super(Scheduler, self).doShutdown() return super(Scheduler, self).doShutdown(*args, **kwargs)
def stop(self): def stop(self):
if self.started: if self.started:

4
couchpotato/core/_base/updater/main.py

@ -142,11 +142,11 @@ class Updater(Plugin):
'success': success 'success': success
} }
def doShutdown(self): def doShutdown(self, *args, **kwargs):
if not Env.get('dev'): if not Env.get('dev'):
removePyc(Env.get('app_dir'), show_logs = False) removePyc(Env.get('app_dir'), show_logs = False)
return super(Updater, self).doShutdown() return super(Updater, self).doShutdown(*args, **kwargs)
class BaseUpdater(Plugin): class BaseUpdater(Plugin):

2
couchpotato/core/plugins/base.py

@ -263,7 +263,7 @@ class Plugin(object):
def afterCall(self, handler): def afterCall(self, handler):
self.isRunning('%s.%s' % (self.getName(), handler.__name__), False) self.isRunning('%s.%s' % (self.getName(), handler.__name__), False)
def doShutdown(self): def doShutdown(self, *args, **kwargs):
self.shuttingDown(True) self.shuttingDown(True)
return True return True

9
couchpotato/runner.py

@ -286,12 +286,13 @@ def runCouchPotato(options, base_path, args, data_dir = None, log_dir = None, En
except: pass except: pass
fireEventAsync('app.load') fireEventAsync('app.load')
ssl_options = None
if config['ssl_cert'] and config['ssl_key']: if config['ssl_cert'] and config['ssl_key']:
server = HTTPServer(application, no_keep_alive = True, ssl_options = { ssl_options = {
'certfile': config['ssl_cert'], 'certfile': config['ssl_cert'],
'keyfile': config['ssl_key'], 'keyfile': config['ssl_key'],
}) }
else:
server = HTTPServer(application, no_keep_alive = True) server = HTTPServer(application, no_keep_alive = True)
try_restart = True try_restart = True
@ -301,6 +302,8 @@ def runCouchPotato(options, base_path, args, data_dir = None, log_dir = None, En
try: try:
server.listen(config['port'], config['host']) server.listen(config['port'], config['host'])
loop.start() loop.start()
server.close_all_connections()
server.stop()
except Exception as e: except Exception as e:
log.error('Failed starting: %s', traceback.format_exc()) log.error('Failed starting: %s', traceback.format_exc())
try: try:

11
couchpotato/static/scripts/couchpotato.js

@ -272,11 +272,18 @@
(function(){ (function(){
Api.request('app.available', { var onFailure = function(){
'onFailure': function(){
self.checkAvailable.delay(1000, self, [delay, onAvailable]); self.checkAvailable.delay(1000, self, [delay, onAvailable]);
self.fireEvent('unload'); self.fireEvent('unload');
}
var request = Api.request('app.available', {
'timeout': 2000,
'onTimeout': function(){
request.cancel();
onFailure();
}, },
'onFailure': onFailure,
'onSuccess': function(){ 'onSuccess': function(){
if(onAvailable) if(onAvailable)
onAvailable(); onAvailable();

Loading…
Cancel
Save