瀏覽代碼

Merge pull request #33546 from runcom/init-runtime-info

daemon: correctly try to retrieve init/runtime versions
Victor Vieux 8 年之前
父節點
當前提交
274cc09247
共有 2 個文件被更改,包括 9 次插入8 次删除
  1. 1 1
      daemon/config/config_common_unix.go
  2. 8 7
      daemon/info_unix.go

+ 1 - 1
daemon/config/config_common_unix.go

@@ -59,7 +59,7 @@ func (conf *Config) GetExecRoot() string {
 	return conf.ExecRoot
 	return conf.ExecRoot
 }
 }
 
 
-// GetInitPath returns the configure docker-init path
+// GetInitPath returns the configured docker-init path
 func (conf *Config) GetInitPath() string {
 func (conf *Config) GetInitPath() string {
 	conf.Lock()
 	conf.Lock()
 	defer conf.Unlock()
 	defer conf.Unlock()

+ 8 - 7
daemon/info_unix.go

@@ -9,7 +9,6 @@ import (
 
 
 	"github.com/Sirupsen/logrus"
 	"github.com/Sirupsen/logrus"
 	"github.com/docker/docker/api/types"
 	"github.com/docker/docker/api/types"
-	daemonconfig "github.com/docker/docker/daemon/config"
 	"github.com/docker/docker/dockerversion"
 	"github.com/docker/docker/dockerversion"
 	"github.com/docker/docker/pkg/sysinfo"
 	"github.com/docker/docker/pkg/sysinfo"
 	"github.com/pkg/errors"
 	"github.com/pkg/errors"
@@ -38,7 +37,8 @@ func (daemon *Daemon) FillPlatformInfo(v *types.Info, sysInfo *sysinfo.SysInfo)
 	}
 	}
 
 
 	v.RuncCommit.Expected = dockerversion.RuncCommitID
 	v.RuncCommit.Expected = dockerversion.RuncCommitID
-	if rv, err := exec.Command(DefaultRuntimeBinary, "--version").Output(); err == nil {
+	defaultRuntimeBinary := daemon.configStore.GetRuntime(daemon.configStore.GetDefaultRuntimeName()).Path
+	if rv, err := exec.Command(defaultRuntimeBinary).Output(); err == nil {
 		parts := strings.Split(strings.TrimSpace(string(rv)), "\n")
 		parts := strings.Split(strings.TrimSpace(string(rv)), "\n")
 		if len(parts) == 3 {
 		if len(parts) == 3 {
 			parts = strings.Split(parts[1], ": ")
 			parts = strings.Split(parts[1], ": ")
@@ -48,23 +48,24 @@ func (daemon *Daemon) FillPlatformInfo(v *types.Info, sysInfo *sysinfo.SysInfo)
 		}
 		}
 
 
 		if v.RuncCommit.ID == "" {
 		if v.RuncCommit.ID == "" {
-			logrus.Warnf("failed to retrieve %s version: unknown output format: %s", DefaultRuntimeBinary, string(rv))
+			logrus.Warnf("failed to retrieve %s version: unknown output format: %s", defaultRuntimeBinary, string(rv))
 			v.RuncCommit.ID = "N/A"
 			v.RuncCommit.ID = "N/A"
 		}
 		}
 	} else {
 	} else {
-		logrus.Warnf("failed to retrieve %s version: %v", DefaultRuntimeBinary, err)
+		logrus.Warnf("failed to retrieve %s version: %v", defaultRuntimeBinary, err)
 		v.RuncCommit.ID = "N/A"
 		v.RuncCommit.ID = "N/A"
 	}
 	}
 
 
-	if rv, err := exec.Command(daemonconfig.DefaultInitBinary, "--version").Output(); err == nil {
+	defaultInitBinary := daemon.configStore.GetInitPath()
+	if rv, err := exec.Command(defaultInitBinary, "--version").Output(); err == nil {
 		ver, err := parseInitVersion(string(rv))
 		ver, err := parseInitVersion(string(rv))
 
 
 		if err != nil {
 		if err != nil {
-			logrus.Warnf("failed to retrieve %s version: %s", daemonconfig.DefaultInitBinary, err)
+			logrus.Warnf("failed to retrieve %s version: %s", defaultInitBinary, err)
 		}
 		}
 		v.InitCommit = ver
 		v.InitCommit = ver
 	} else {
 	} else {
-		logrus.Warnf("failed to retrieve %s version: %s", daemonconfig.DefaultInitBinary, err)
+		logrus.Warnf("failed to retrieve %s version: %s", defaultInitBinary, err)
 		v.InitCommit.ID = "N/A"
 		v.InitCommit.ID = "N/A"
 	}
 	}
 }
 }