From 5875bc1066239983817aa95bd00600285874972a Mon Sep 17 00:00:00 2001 From: "Dave Walker (Daviey)" Date: Wed, 1 Mar 2017 00:18:47 +0000 Subject: [PATCH 1/2] Don't exec uname for node attribute kernel.version Previously with client fingerprinting, sys/exec's Command function was being used to execute `uname -r` and the return string processed into the kernel.version node attribute. This change uses gopsutil/host KernelVersion function instead. This means we can drop the os/exec, strings and fmt imports... and not execute an external binary. Signed-off-by: Dave Walker (Daviey) --- CHANGELOG.md | 1 + client/fingerprint/host.go | 9 +-------- 2 files changed, 2 insertions(+), 8 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 328ed9a7423..1d00fcc18ca 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -19,6 +19,7 @@ IMPROVEMENTS: * client: Don't force uppercase meta keys in env vars [GH-2338] * client: Reproducible Node ID on OSes that provide system-level UUID [GH-2277] + * client: Don't exec `uname -r` for node attribute kernel.version [GH-2380] * driver/docker: Add support for volume drivers [GH-2351] * driver/docker: Docker image coordinator and caching [GH-2361] * jobspec: Add leader task to allow graceful shutdown of other tasks within diff --git a/client/fingerprint/host.go b/client/fingerprint/host.go index a40a473f608..5d9925924e5 100644 --- a/client/fingerprint/host.go +++ b/client/fingerprint/host.go @@ -1,11 +1,8 @@ package fingerprint import ( - "fmt" "log" - "os/exec" "runtime" - "strings" "github.com/hashicorp/nomad/client/config" "github.com/hashicorp/nomad/nomad/structs" @@ -38,11 +35,7 @@ func (f *HostFingerprint) Fingerprint(cfg *config.Config, node *structs.Node) (b node.Attributes["kernel.version"] = "" if runtime.GOOS != "windows" { - out, err := exec.Command("uname", "-r").Output() - if err != nil { - return false, fmt.Errorf("Failed to run uname: %s", err) - } - node.Attributes["kernel.version"] = strings.Trim(string(out), "\n") + node.Attributes["kernel.version"] = hostInfo.KernelVersion } node.Attributes["unique.hostname"] = hostInfo.Hostname From 5d484dcb9640786b9b0c7d631756745a3a4001e3 Mon Sep 17 00:00:00 2001 From: "Dave Walker (Daviey)" Date: Wed, 1 Mar 2017 18:48:23 +0000 Subject: [PATCH 2/2] Enable kernel.version on Windows Previously, this value was guarded against running on Windows because it called the `uname` command which is unlikely to be there. This change now sets the value from gopsutil, which might well be an empty string. Signed-off-by: Dave Walker (Daviey) --- client/fingerprint/host.go | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/client/fingerprint/host.go b/client/fingerprint/host.go index 5d9925924e5..a7b8ed6c8ae 100644 --- a/client/fingerprint/host.go +++ b/client/fingerprint/host.go @@ -32,11 +32,7 @@ func (f *HostFingerprint) Fingerprint(cfg *config.Config, node *structs.Node) (b node.Attributes["os.version"] = hostInfo.PlatformVersion node.Attributes["kernel.name"] = runtime.GOOS - node.Attributes["kernel.version"] = "" - - if runtime.GOOS != "windows" { - node.Attributes["kernel.version"] = hostInfo.KernelVersion - } + node.Attributes["kernel.version"] = hostInfo.KernelVersion node.Attributes["unique.hostname"] = hostInfo.Hostname