Merge pull request #71 from Random-Liu/add-version-flag

Add --version flag.
This commit is contained in:
Lantao Liu
2017-01-13 10:52:05 -08:00
committed by GitHub
3 changed files with 47 additions and 7 deletions

View File

@@ -1,13 +1,16 @@
.PHONY: all container push clean node-problem-detector vet fmt
.PHONY: all container push clean node-problem-detector vet fmt version
all: push
# See node-problem-detector.yaml for the version currently running-- bump this ahead before rebuilding!
TAG = v0.2
VERSION := $(shell git describe --tags --dirty)
TAG ?= $(VERSION)
PROJ = google_containers
PKG_SOURCES := $(shell find pkg -name '*.go')
PKG := k8s.io/node-problem-detector
PKG_SOURCES := $(shell find pkg cmd -name '*.go')
vet:
go list ./... | grep -v "./vendor/*" | xargs go vet
@@ -15,8 +18,13 @@ vet:
fmt:
find . -type f -name "*.go" | grep -v "./vendor/*" | xargs gofmt -s -w -l
node-problem-detector: $(PKG_SOURCES) node_problem_detector.go fmt vet
GOOS=linux go build -ldflags '-w -extldflags "-static"' -o node-problem-detector
version:
@echo $(VERSION)
node-problem-detector: $(PKG_SOURCES) fmt vet
GOOS=linux go build -o node-problem-detector \
-ldflags '-w -extldflags "-static" -X $(PKG)/pkg/version.version=$(VERSION)' \
cmd/node_problem_detector.go
test:
go test -timeout=1m -v -race ./pkg/...

View File

@@ -19,16 +19,20 @@ package main
import (
"flag"
"net/url"
"os"
"k8s.io/node-problem-detector/pkg/kernelmonitor"
"k8s.io/node-problem-detector/pkg/problemdetector"
"k8s.io/node-problem-detector/pkg/version"
"github.com/golang/glog"
)
// TODO: Move flags to options directory.
var (
kernelMonitorConfigPath = flag.String("kernel-monitor", "/config/kernel-monitor.json", "The path to the kernel monitor config file")
apiServerOverride = flag.String("apiserver-override", "", "custom URI used to connect to Kubernetes ApiServer")
apiServerOverride = flag.String("apiserver-override", "", "Custom URI used to connect to Kubernetes ApiServer")
printVersion = flag.Bool("version", false, "Print version information and quit")
)
func validateCmdParams() {
@@ -41,6 +45,11 @@ func main() {
flag.Parse()
validateCmdParams()
if *printVersion {
version.PrintVersion()
os.Exit(0)
}
k := kernelmonitor.NewKernelMonitorOrDie(*kernelMonitorConfigPath)
p := problemdetector.NewProblemDetector(k, *apiServerOverride)
p.Run()

23
pkg/version/version.go Normal file
View File

@@ -0,0 +1,23 @@
/*
Copyright 2016 The Kubernetes Authors.
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 version
import "fmt"
// version defines the version
var version string = "UNKNOWN"
func PrintVersion() {
fmt.Println(version)
}