package main import ( "log" "os" "os/signal" "runtime" "runtime/debug" "syscall" "time" ) const version = "2.4.0" type ctxKey string func initialize() { log.SetOutput(os.Stdout) initSyslog() configure() initNewrelic() initPrometheus() initDownloading() initErrorsReporting() initVips() } func main() { initialize() go func() { var logMemStats = len(os.Getenv("IMGPROXY_LOG_MEM_STATS")) > 0 for range time.Tick(time.Duration(conf.FreeMemoryInterval) * time.Second) { debug.FreeOSMemory() if logMemStats { var m runtime.MemStats runtime.ReadMemStats(&m) logNotice("[MEMORY USAGE] Sys: %d; HeapIdle: %d; HeapInuse: %d", m.Sys/1024/1024, m.HeapIdle/1024/1024, m.HeapInuse/1024/1024) } } }() s := startServer() stop := make(chan os.Signal, 1) signal.Notify(stop, syscall.SIGINT, syscall.SIGTERM) <-stop shutdownServer(s) shutdownVips() }