1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- package main
- import (
- "io"
- "path/filepath"
- "github.com/Microsoft/go-winio/pkg/etwlogrus"
- "github.com/containerd/log"
- )
- func runDaemon(opts *daemonOptions) error {
- daemonCli := NewDaemonCli()
- // On Windows, this may be launching as a service or with an option to
- // register the service.
- stop, runAsService, err := initService(daemonCli)
- if err != nil {
- return err
- }
- if stop {
- return nil
- }
- // Windows specific settings as these are not defaulted.
- if opts.configFile == "" {
- opts.configFile = filepath.Join(opts.daemonConfig.Root, "config", "daemon.json")
- }
- if runAsService {
- // If Windows SCM manages the service - no need for PID files
- opts.daemonConfig.Pidfile = ""
- } else if opts.daemonConfig.Pidfile == "" {
- opts.daemonConfig.Pidfile = filepath.Join(opts.daemonConfig.Root, "docker.pid")
- }
- err = daemonCli.start(opts)
- notifyShutdown(err)
- return err
- }
- func initLogging(stdout, _ io.Writer) {
- // Maybe there is a historic reason why on non-Windows, stderr is used
- // for output. However, on Windows it makes no sense and there is no need.
- log.L.Logger.SetOutput(stdout)
- // Provider ID: {6996f090-c5de-5082-a81e-5841acc3a635}
- // Hook isn't closed explicitly, as it will exist until process exit.
- // GUID is generated based on name - see Microsoft/go-winio/tools/etw-provider-gen.
- if hook, err := etwlogrus.NewHook("Moby"); err == nil {
- log.L.Logger.AddHook(hook)
- }
- return
- }
|