Skip to content

Commit

Permalink
Don't exec uname for node attribute kernel.version
Browse files Browse the repository at this point in the history
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) <[email protected]>
  • Loading branch information
Daviey committed Mar 1, 2017
1 parent 8e6d77e commit 5875bc1
Show file tree
Hide file tree
Showing 2 changed files with 2 additions and 8 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
9 changes: 1 addition & 8 deletions client/fingerprint/host.go
Original file line number Diff line number Diff line change
@@ -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"
Expand Down Expand Up @@ -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
Expand Down

0 comments on commit 5875bc1

Please sign in to comment.