mirror of
https://github.com/minio/minio.git
synced 2024-12-24 22:25:54 -05:00
a0d0645128
In almost all scenarios MinIO now is mostly ready for all sub-systems independently, safe-mode is not useful anymore and do not serve its original intended purpose. allow server to be fully functional even with config partially configured, this is to cater for availability of actual I/O v/s manually fixing the server. In k8s like environments it will never make sense to take pod into safe-mode state, because there is no real access to perform any remote operation on them.
93 lines
2.2 KiB
Go
93 lines
2.2 KiB
Go
/*
|
|
* MinIO Cloud Storage, (C) 2015-2019 MinIO, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package cmd
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"net/http"
|
|
"os"
|
|
"strings"
|
|
|
|
"github.com/minio/minio/cmd/logger"
|
|
)
|
|
|
|
func handleSignals() {
|
|
// Custom exit function
|
|
exit := func(success bool) {
|
|
// If global profiler is set stop before we exit.
|
|
globalProfilerMu.Lock()
|
|
defer globalProfilerMu.Unlock()
|
|
for _, p := range globalProfiler {
|
|
p.Stop()
|
|
}
|
|
|
|
if success {
|
|
os.Exit(0)
|
|
}
|
|
|
|
os.Exit(1)
|
|
}
|
|
|
|
stopProcess := func() bool {
|
|
var err, oerr error
|
|
|
|
// send signal to various go-routines that they need to quit.
|
|
cancelGlobalContext()
|
|
|
|
if globalNotificationSys != nil {
|
|
globalNotificationSys.RemoveAllRemoteTargets()
|
|
}
|
|
|
|
if httpServer := newHTTPServerFn(); httpServer != nil {
|
|
err = httpServer.Shutdown()
|
|
if !errors.Is(err, http.ErrServerClosed) {
|
|
logger.LogIf(context.Background(), err)
|
|
}
|
|
}
|
|
|
|
if objAPI := newObjectLayerFn(); objAPI != nil {
|
|
oerr = objAPI.Shutdown(context.Background())
|
|
logger.LogIf(context.Background(), oerr)
|
|
}
|
|
|
|
return (err == nil && oerr == nil)
|
|
}
|
|
|
|
for {
|
|
select {
|
|
case <-globalHTTPServerErrorCh:
|
|
exit(stopProcess())
|
|
case osSignal := <-globalOSSignalCh:
|
|
logger.Info("Exiting on signal: %s", strings.ToUpper(osSignal.String()))
|
|
exit(stopProcess())
|
|
case signal := <-globalServiceSignalCh:
|
|
switch signal {
|
|
case serviceRestart:
|
|
logger.Info("Restarting on service signal")
|
|
stop := stopProcess()
|
|
rerr := restartProcess()
|
|
logger.LogIf(context.Background(), rerr)
|
|
exit(stop && rerr == nil)
|
|
case serviceStop:
|
|
logger.Info("Stopping on service signal")
|
|
exit(stopProcess())
|
|
}
|
|
}
|
|
}
|
|
}
|