Avoid panic if reloading before server is started

See: https://forum.caddyserver.com/t/reloading-template-files-as-they-change/1483/3?u=matt

The server takes a moment to start; if USR1 is received before the
instance is saved, it would panic because no instances have been saved.
Instead, we just ignore the signal since no config has finished loading.
This commit is contained in:
Matthew Holt 2017-03-06 19:20:13 -07:00
parent 75ccc05d84
commit c8514ad7b7

View file

@ -49,8 +49,14 @@ func trapSignalsPosix() {
// Start with the existing Caddyfile // Start with the existing Caddyfile
instancesMu.Lock() instancesMu.Lock()
if len(instances) == 0 {
instancesMu.Unlock()
log.Println("[ERROR] SIGUSR1: No server instances are fully running")
continue
}
inst := instances[0] // we only support one instance at this time inst := instances[0] // we only support one instance at this time
instancesMu.Unlock() instancesMu.Unlock()
updatedCaddyfile := inst.caddyfileInput updatedCaddyfile := inst.caddyfileInput
if updatedCaddyfile == nil { if updatedCaddyfile == nil {
// Hmm, did spawing process forget to close stdin? Anyhow, this is unusual. // Hmm, did spawing process forget to close stdin? Anyhow, this is unusual.