mirror of
https://github.com/overleaf/overleaf.git
synced 2025-02-18 16:53:00 +00:00
allow PackWorker to shut down cleanly
This commit is contained in:
parent
ffe30962c9
commit
cb109a27a6
1 changed files with 15 additions and 3 deletions
|
@ -18,7 +18,7 @@ DOCUMENT_PACK_DELAY = Number(process.argv[3]) || 1000
|
||||||
TIMEOUT = Number(process.argv[4]) || 30*60*1000
|
TIMEOUT = Number(process.argv[4]) || 30*60*1000
|
||||||
|
|
||||||
shutDownRequested = false
|
shutDownRequested = false
|
||||||
setTimeout () ->
|
shutDownTimer = setTimeout () ->
|
||||||
logger.log "pack timed out, requesting shutdown"
|
logger.log "pack timed out, requesting shutdown"
|
||||||
# start the shutdown on the next pack
|
# start the shutdown on the next pack
|
||||||
shutDownRequested = true
|
shutDownRequested = true
|
||||||
|
@ -40,10 +40,22 @@ db.close = (callback) ->
|
||||||
callback()
|
callback()
|
||||||
|
|
||||||
finish = () ->
|
finish = () ->
|
||||||
|
if shutDownTimer?
|
||||||
|
logger.log 'cancelling timeout'
|
||||||
|
clearTimeout shutDownTimer
|
||||||
logger.log 'closing db'
|
logger.log 'closing db'
|
||||||
db.close () ->
|
db.close () ->
|
||||||
logger.log 'exiting from pack worker'
|
logger.log 'closing LockManager Redis Connection'
|
||||||
process.exit()
|
LockManager.close () ->
|
||||||
|
logger.log 'ready to exit from pack worker'
|
||||||
|
hardTimeout = setTimeout () ->
|
||||||
|
logger.error 'hard exit from pack worker'
|
||||||
|
process.exit(1)
|
||||||
|
, 5*1000
|
||||||
|
hardTimeout.unref()
|
||||||
|
|
||||||
|
process.on 'exit', (code) ->
|
||||||
|
logger.log {code}, 'pack worker exited'
|
||||||
|
|
||||||
processUpdates = (pending) ->
|
processUpdates = (pending) ->
|
||||||
async.eachSeries pending, (doc_id, callback) ->
|
async.eachSeries pending, (doc_id, callback) ->
|
||||||
|
|
Loading…
Reference in a new issue