mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-12 14:27:27 -08:00
Merge pull request #1614 from sdurrheimer/common-version
Make version informations consistent between prometheus components
This commit is contained in:
commit
baa3e19fa0
10
.promu.yml
10
.promu.yml
|
@ -9,11 +9,11 @@ build:
|
||||||
path: ./cmd/promtool
|
path: ./cmd/promtool
|
||||||
flags: -a -tags netgo
|
flags: -a -tags netgo
|
||||||
ldflags: |
|
ldflags: |
|
||||||
-X {{repoPath}}/version.Version={{.Version}}
|
-X {{repoPath}}/vendor/github.com/prometheus/common/version.Version={{.Version}}
|
||||||
-X {{repoPath}}/version.Revision={{.Revision}}
|
-X {{repoPath}}/vendor/github.com/prometheus/common/version.Revision={{.Revision}}
|
||||||
-X {{repoPath}}/version.Branch={{.Branch}}
|
-X {{repoPath}}/vendor/github.com/prometheus/common/version.Branch={{.Branch}}
|
||||||
-X {{repoPath}}/version.BuildUser={{user}}@{{host}}
|
-X {{repoPath}}/vendor/github.com/prometheus/common/version.BuildUser={{user}}@{{host}}
|
||||||
-X {{repoPath}}/version.BuildDate={{date "20060102-15:04:05"}}
|
-X {{repoPath}}/vendor/github.com/prometheus/common/version.BuildDate={{date "20060102-15:04:05"}}
|
||||||
tarball:
|
tarball:
|
||||||
files:
|
files:
|
||||||
- consoles
|
- consoles
|
||||||
|
|
|
@ -15,21 +15,17 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
_ "net/http/pprof" // Comment this line to disable pprof endpoint.
|
_ "net/http/pprof" // Comment this line to disable pprof endpoint.
|
||||||
"os"
|
"os"
|
||||||
"os/signal"
|
"os/signal"
|
||||||
"strings"
|
|
||||||
"syscall"
|
"syscall"
|
||||||
"text/template"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/common/log"
|
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
"github.com/prometheus/common/log"
|
||||||
|
"github.com/prometheus/common/version"
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/notifier"
|
"github.com/prometheus/prometheus/notifier"
|
||||||
"github.com/prometheus/prometheus/promql"
|
"github.com/prometheus/prometheus/promql"
|
||||||
|
@ -38,7 +34,6 @@ import (
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
"github.com/prometheus/prometheus/storage/local"
|
"github.com/prometheus/prometheus/storage/local"
|
||||||
"github.com/prometheus/prometheus/storage/remote"
|
"github.com/prometheus/prometheus/storage/remote"
|
||||||
"github.com/prometheus/prometheus/version"
|
|
||||||
"github.com/prometheus/prometheus/web"
|
"github.com/prometheus/prometheus/web"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -59,6 +54,10 @@ var (
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
prometheus.MustRegister(version.NewCollector("prometheus"))
|
||||||
|
}
|
||||||
|
|
||||||
// Main manages the startup and shutdown lifecycle of the entire Prometheus server.
|
// Main manages the startup and shutdown lifecycle of the entire Prometheus server.
|
||||||
func Main() int {
|
func Main() int {
|
||||||
if err := parse(os.Args[1:]); err != nil {
|
if err := parse(os.Args[1:]); err != nil {
|
||||||
|
@ -66,11 +65,14 @@ func Main() int {
|
||||||
return 2
|
return 2
|
||||||
}
|
}
|
||||||
|
|
||||||
printVersion()
|
|
||||||
if cfg.printVersion {
|
if cfg.printVersion {
|
||||||
|
fmt.Fprintln(os.Stdout, version.Print("prometheus"))
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
log.Infoln("Starting prometheus", version.Info())
|
||||||
|
log.Infoln("Build context", version.BuildContext())
|
||||||
|
|
||||||
var reloadables []Reloadable
|
var reloadables []Reloadable
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
@ -108,7 +110,16 @@ func Main() int {
|
||||||
Birth: time.Now(),
|
Birth: time.Now(),
|
||||||
}
|
}
|
||||||
|
|
||||||
webHandler := web.New(memStorage, queryEngine, ruleManager, status, &cfg.web)
|
version := &web.PrometheusVersion{
|
||||||
|
Version: version.Version,
|
||||||
|
Revision: version.Revision,
|
||||||
|
Branch: version.Branch,
|
||||||
|
BuildUser: version.BuildUser,
|
||||||
|
BuildDate: version.BuildDate,
|
||||||
|
GoVersion: version.GoVersion,
|
||||||
|
}
|
||||||
|
|
||||||
|
webHandler := web.New(memStorage, queryEngine, ruleManager, status, version, &cfg.web)
|
||||||
|
|
||||||
reloadables = append(reloadables, status, targetManager, ruleManager, webHandler, notifier)
|
reloadables = append(reloadables, status, targetManager, ruleManager, webHandler, notifier)
|
||||||
|
|
||||||
|
@ -221,20 +232,3 @@ func reloadConfig(filename string, rls ...Reloadable) (success bool) {
|
||||||
}
|
}
|
||||||
return success
|
return success
|
||||||
}
|
}
|
||||||
|
|
||||||
var versionInfoTmpl = `
|
|
||||||
prometheus, version {{.version}} (branch: {{.branch}}, revision: {{.revision}})
|
|
||||||
build user: {{.buildUser}}
|
|
||||||
build date: {{.buildDate}}
|
|
||||||
go version: {{.goVersion}}
|
|
||||||
`
|
|
||||||
|
|
||||||
func printVersion() {
|
|
||||||
t := template.Must(template.New("version").Parse(versionInfoTmpl))
|
|
||||||
|
|
||||||
var buf bytes.Buffer
|
|
||||||
if err := t.ExecuteTemplate(&buf, "version", version.Map); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Fprintln(os.Stdout, strings.TrimSpace(buf.String()))
|
|
||||||
}
|
|
||||||
|
|
|
@ -14,18 +14,16 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
"text/template"
|
|
||||||
|
|
||||||
|
"github.com/prometheus/common/version"
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/promql"
|
"github.com/prometheus/prometheus/promql"
|
||||||
"github.com/prometheus/prometheus/util/cli"
|
"github.com/prometheus/prometheus/util/cli"
|
||||||
"github.com/prometheus/prometheus/version"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// CheckConfigCmd validates configuration files.
|
// CheckConfigCmd validates configuration files.
|
||||||
|
@ -184,22 +182,9 @@ func checkRules(t cli.Term, filename string) (int, error) {
|
||||||
return len(rules), nil
|
return len(rules), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
var versionInfoTmpl = `
|
|
||||||
prometheus, version {{.version}} (branch: {{.branch}}, revision: {{.revision}})
|
|
||||||
build user: {{.buildUser}}
|
|
||||||
build date: {{.buildDate}}
|
|
||||||
go version: {{.goVersion}}
|
|
||||||
`
|
|
||||||
|
|
||||||
// VersionCmd prints the binaries version information.
|
// VersionCmd prints the binaries version information.
|
||||||
func VersionCmd(t cli.Term, _ ...string) int {
|
func VersionCmd(t cli.Term, _ ...string) int {
|
||||||
tmpl := template.Must(template.New("version").Parse(versionInfoTmpl))
|
fmt.Fprintln(os.Stdout, version.Print("promtool"))
|
||||||
|
|
||||||
var buf bytes.Buffer
|
|
||||||
if err := tmpl.ExecuteTemplate(&buf, "version", version.Map); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Fprintln(t.Out(), strings.TrimSpace(buf.String()))
|
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,16 +14,12 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"strings"
|
|
||||||
"text/template"
|
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/cli"
|
|
||||||
"github.com/prometheus/prometheus/version"
|
|
||||||
|
|
||||||
|
"github.com/prometheus/common/version"
|
||||||
"github.com/prometheus/prometheus/storage/local"
|
"github.com/prometheus/prometheus/storage/local"
|
||||||
|
"github.com/prometheus/prometheus/util/cli"
|
||||||
)
|
)
|
||||||
|
|
||||||
// DumpHeadsCmd dumps metadata of a heads.db file.
|
// DumpHeadsCmd dumps metadata of a heads.db file.
|
||||||
|
@ -39,22 +35,9 @@ func DumpHeadsCmd(t cli.Term, args ...string) int {
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
var versionInfoTmpl = `
|
|
||||||
prometheus, version {{.version}} (branch: {{.branch}}, revision: {{.revision}})
|
|
||||||
build user: {{.buildUser}}
|
|
||||||
build date: {{.buildDate}}
|
|
||||||
go version: {{.goVersion}}
|
|
||||||
`
|
|
||||||
|
|
||||||
// VersionCmd prints the binaries version information.
|
// VersionCmd prints the binaries version information.
|
||||||
func VersionCmd(t cli.Term, _ ...string) int {
|
func VersionCmd(t cli.Term, _ ...string) int {
|
||||||
tmpl := template.Must(template.New("version").Parse(versionInfoTmpl))
|
fmt.Fprintln(os.Stdout, version.Print("storagetool"))
|
||||||
|
|
||||||
var buf bytes.Buffer
|
|
||||||
if err := tmpl.ExecuteTemplate(&buf, "version", version.Map); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Fprintln(t.Out(), strings.TrimSpace(buf.String()))
|
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
89
vendor/github.com/prometheus/common/version/info.go
generated
vendored
Normal file
89
vendor/github.com/prometheus/common/version/info.go
generated
vendored
Normal file
|
@ -0,0 +1,89 @@
|
||||||
|
// Copyright 2016 The Prometheus 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 (
|
||||||
|
"bytes"
|
||||||
|
"fmt"
|
||||||
|
"runtime"
|
||||||
|
"strings"
|
||||||
|
"text/template"
|
||||||
|
|
||||||
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Build information. Populated at build-time.
|
||||||
|
var (
|
||||||
|
Version string
|
||||||
|
Revision string
|
||||||
|
Branch string
|
||||||
|
BuildUser string
|
||||||
|
BuildDate string
|
||||||
|
GoVersion = runtime.Version()
|
||||||
|
)
|
||||||
|
|
||||||
|
// NewCollector returns a collector which exports metrics about current version information.
|
||||||
|
func NewCollector(program string) *prometheus.GaugeVec {
|
||||||
|
buildInfo := prometheus.NewGaugeVec(
|
||||||
|
prometheus.GaugeOpts{
|
||||||
|
Namespace: program,
|
||||||
|
Name: "build_info",
|
||||||
|
Help: fmt.Sprintf(
|
||||||
|
"A metric with a constant '1' value labeled by version, revision, branch, and goversion from which %s was built.",
|
||||||
|
program,
|
||||||
|
),
|
||||||
|
},
|
||||||
|
[]string{"version", "revision", "branch", "goversion"},
|
||||||
|
)
|
||||||
|
buildInfo.WithLabelValues(Version, Revision, Branch, GoVersion).Set(1)
|
||||||
|
return buildInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
// versionInfoTmpl contains the template used by Info.
|
||||||
|
var versionInfoTmpl = `
|
||||||
|
{{.program}}, version {{.version}} (branch: {{.branch}}, revision: {{.revision}})
|
||||||
|
build user: {{.buildUser}}
|
||||||
|
build date: {{.buildDate}}
|
||||||
|
go version: {{.goVersion}}
|
||||||
|
`
|
||||||
|
|
||||||
|
// Print returns version information.
|
||||||
|
func Print(program string) string {
|
||||||
|
m := map[string]string{
|
||||||
|
"program": program,
|
||||||
|
"version": Version,
|
||||||
|
"revision": Revision,
|
||||||
|
"branch": Branch,
|
||||||
|
"buildUser": BuildUser,
|
||||||
|
"buildDate": BuildDate,
|
||||||
|
"goVersion": GoVersion,
|
||||||
|
}
|
||||||
|
t := template.Must(template.New("version").Parse(versionInfoTmpl))
|
||||||
|
|
||||||
|
var buf bytes.Buffer
|
||||||
|
if err := t.ExecuteTemplate(&buf, "version", m); err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
return strings.TrimSpace(buf.String())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Info returns version, branch and revision information.
|
||||||
|
func Info() string {
|
||||||
|
return fmt.Sprintf("(version=%s, branch=%s, revision=%s)", Version, Branch, Revision)
|
||||||
|
}
|
||||||
|
|
||||||
|
// BuildContext returns goVersion, buildUser and buildDate information.
|
||||||
|
func BuildContext() string {
|
||||||
|
return fmt.Sprintf("(go=%s, user=%s, date=%s)", GoVersion, BuildUser, BuildDate)
|
||||||
|
}
|
6
vendor/vendor.json
vendored
6
vendor/vendor.json
vendored
|
@ -185,6 +185,12 @@
|
||||||
"revision": "14ca1097bbe21584194c15e391a9dab95ad42a59",
|
"revision": "14ca1097bbe21584194c15e391a9dab95ad42a59",
|
||||||
"revisionTime": "2016-01-25T23:57:51+01:00"
|
"revisionTime": "2016-01-25T23:57:51+01:00"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"checksumSHA1": "91KYK0SpvkaMJJA2+BcxbVnyRO0=",
|
||||||
|
"path": "github.com/prometheus/common/version",
|
||||||
|
"revision": "dd586c1c5abb0be59e60f942c22af711a2008cb4",
|
||||||
|
"revisionTime": "2016-05-03T22:05:32Z"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"path": "github.com/prometheus/procfs",
|
"path": "github.com/prometheus/procfs",
|
||||||
"revision": "c91d8eefde16bd047416409eb56353ea84a186e4",
|
"revision": "c91d8eefde16bd047416409eb56353ea84a186e4",
|
||||||
|
|
|
@ -1,53 +0,0 @@
|
||||||
// Copyright 2015 The Prometheus 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 (
|
|
||||||
"runtime"
|
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Build information. Populated at build-time.
|
|
||||||
var (
|
|
||||||
Version string
|
|
||||||
Revision string
|
|
||||||
Branch string
|
|
||||||
BuildUser string
|
|
||||||
BuildDate string
|
|
||||||
GoVersion = runtime.Version()
|
|
||||||
)
|
|
||||||
|
|
||||||
// Map provides the iterable version information.
|
|
||||||
var Map = map[string]string{
|
|
||||||
"version": Version,
|
|
||||||
"revision": Revision,
|
|
||||||
"branch": Branch,
|
|
||||||
"buildUser": BuildUser,
|
|
||||||
"buildDate": BuildDate,
|
|
||||||
"goVersion": GoVersion,
|
|
||||||
}
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
buildInfo := prometheus.NewGaugeVec(
|
|
||||||
prometheus.GaugeOpts{
|
|
||||||
Name: "prometheus_build_info",
|
|
||||||
Help: "A metric with a constant '1' value labeled by version, revision, branch, and goversion from which Prometheus was built.",
|
|
||||||
},
|
|
||||||
[]string{"version", "revision", "branch", "goversion"},
|
|
||||||
)
|
|
||||||
buildInfo.WithLabelValues(Version, Revision, Branch, GoVersion).Set(1)
|
|
||||||
|
|
||||||
prometheus.MustRegister(buildInfo)
|
|
||||||
}
|
|
File diff suppressed because one or more lines are too long
|
@ -15,12 +15,30 @@
|
||||||
<h2 id="buildinformation">Build Information</h2>
|
<h2 id="buildinformation">Build Information</h2>
|
||||||
<table class="table table-condensed table-bordered table-striped table-hover">
|
<table class="table table-condensed table-bordered table-striped table-hover">
|
||||||
<tbody>
|
<tbody>
|
||||||
{{range $key, $value := .Info}}
|
|
||||||
<tr>
|
<tr>
|
||||||
<th scope="row">{{$key}}</th>
|
<th scope="row">Version</th>
|
||||||
<td>{{$value}}</td>
|
<td>{{.Version.Version}}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th scope="row">Revision</th>
|
||||||
|
<td>{{.Version.Revision}}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th scope="row">Branch</th>
|
||||||
|
<td>{{.Version.Branch}}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th scope="row">BuildUser</th>
|
||||||
|
<td>{{.Version.BuildUser}}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th scope="row">BuildDate</th>
|
||||||
|
<td>{{.Version.BuildDate}}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th scope="row">GoVersion</th>
|
||||||
|
<td>{{.Version.GoVersion}}</td>
|
||||||
</tr>
|
</tr>
|
||||||
{{end}}
|
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
|
25
web/web.go
25
web/web.go
|
@ -44,7 +44,6 @@ import (
|
||||||
"github.com/prometheus/prometheus/storage/local"
|
"github.com/prometheus/prometheus/storage/local"
|
||||||
"github.com/prometheus/prometheus/template"
|
"github.com/prometheus/prometheus/template"
|
||||||
"github.com/prometheus/prometheus/util/httputil"
|
"github.com/prometheus/prometheus/util/httputil"
|
||||||
"github.com/prometheus/prometheus/version"
|
|
||||||
"github.com/prometheus/prometheus/web/api/legacy"
|
"github.com/prometheus/prometheus/web/api/legacy"
|
||||||
"github.com/prometheus/prometheus/web/api/v1"
|
"github.com/prometheus/prometheus/web/api/v1"
|
||||||
"github.com/prometheus/prometheus/web/ui"
|
"github.com/prometheus/prometheus/web/ui"
|
||||||
|
@ -67,6 +66,7 @@ type Handler struct {
|
||||||
reloadCh chan struct{}
|
reloadCh chan struct{}
|
||||||
options *Options
|
options *Options
|
||||||
statusInfo *PrometheusStatus
|
statusInfo *PrometheusStatus
|
||||||
|
versionInfo *PrometheusVersion
|
||||||
|
|
||||||
externalLabels model.LabelSet
|
externalLabels model.LabelSet
|
||||||
mtx sync.RWMutex
|
mtx sync.RWMutex
|
||||||
|
@ -110,6 +110,16 @@ func (s *PrometheusStatus) ApplyConfig(conf *config.Config) bool {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// PrometheusVersion contains various build information about Prometheus
|
||||||
|
type PrometheusVersion struct {
|
||||||
|
Version string `json:"version"`
|
||||||
|
Revision string `json:"revision"`
|
||||||
|
Branch string `json:"branch"`
|
||||||
|
BuildUser string `json:"buildUser"`
|
||||||
|
BuildDate string `json:"buildDate"`
|
||||||
|
GoVersion string `json:"goVersion"`
|
||||||
|
}
|
||||||
|
|
||||||
// Options for the web Handler.
|
// Options for the web Handler.
|
||||||
type Options struct {
|
type Options struct {
|
||||||
ListenAddress string
|
ListenAddress string
|
||||||
|
@ -123,7 +133,7 @@ type Options struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
// New initializes a new web Handler.
|
// New initializes a new web Handler.
|
||||||
func New(st local.Storage, qe *promql.Engine, rm *rules.Manager, status *PrometheusStatus, o *Options) *Handler {
|
func New(st local.Storage, qe *promql.Engine, rm *rules.Manager, status *PrometheusStatus, version *PrometheusVersion, o *Options) *Handler {
|
||||||
router := route.New()
|
router := route.New()
|
||||||
|
|
||||||
h := &Handler{
|
h := &Handler{
|
||||||
|
@ -133,6 +143,7 @@ func New(st local.Storage, qe *promql.Engine, rm *rules.Manager, status *Prometh
|
||||||
reloadCh: make(chan struct{}),
|
reloadCh: make(chan struct{}),
|
||||||
options: o,
|
options: o,
|
||||||
statusInfo: status,
|
statusInfo: status,
|
||||||
|
versionInfo: version,
|
||||||
|
|
||||||
ruleManager: rm,
|
ruleManager: rm,
|
||||||
queryEngine: qe,
|
queryEngine: qe,
|
||||||
|
@ -315,17 +326,17 @@ func (h *Handler) status(w http.ResponseWriter, r *http.Request) {
|
||||||
defer h.statusInfo.mu.RUnlock()
|
defer h.statusInfo.mu.RUnlock()
|
||||||
|
|
||||||
h.executeTemplate(w, "status.html", struct {
|
h.executeTemplate(w, "status.html", struct {
|
||||||
Status *PrometheusStatus
|
Status *PrometheusStatus
|
||||||
Info map[string]string
|
Version *PrometheusVersion
|
||||||
}{
|
}{
|
||||||
Status: h.statusInfo,
|
Status: h.statusInfo,
|
||||||
Info: version.Map,
|
Version: h.versionInfo,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *Handler) version(w http.ResponseWriter, r *http.Request) {
|
func (h *Handler) version(w http.ResponseWriter, r *http.Request) {
|
||||||
dec := json.NewEncoder(w)
|
dec := json.NewEncoder(w)
|
||||||
if err := dec.Encode(version.Map); err != nil {
|
if err := dec.Encode(h.versionInfo); err != nil {
|
||||||
http.Error(w, fmt.Sprintf("error encoding JSON: %s", err), http.StatusInternalServerError)
|
http.Error(w, fmt.Sprintf("error encoding JSON: %s", err), http.StatusInternalServerError)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue