-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.go
68 lines (57 loc) · 1.6 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
package main
import (
"flag"
"log"
"net/http"
"os"
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/prometheus/promhttp"
)
// インデックスページ用 (Prometheusは別にココを触らないので、お好みで……)
func indexPage(w http.ResponseWriter, r *http.Request) {
w.Write([]byte(`
<!DOCTYPE html>
<html>
<head>
<title>ConoHa Exporter</title>
</head>
<body>
<h1>ConoHa Exporter</h1>
<p><a href="/metrics">Metrics</a></p>
</body>
</html>
`))
}
func main() {
log.Println("ConoHa exporter started.")
// コマンドライン引数
port := flag.String("port", os.Getenv("PORT"), "Port number to listen on")
region := flag.String("region", "tyo1", "ConoHa region")
tenantId := flag.String("tenant-id", "", "ConoHa tenant ID")
username := flag.String("username", "", "ConoHa API user name")
password := flag.String("password", "", "ConoHa API user password")
flag.Parse()
if *port == "" {
*port = "3000"
}
// ConoHa APIクライアントを作成
client, err := NewClient(*region, *tenantId, *username, *password)
if err != nil {
log.Fatal(err)
}
// 実装したCollectorのを作成
exporter, err := NewConohaCollector(client)
if err != nil {
log.Fatal(err)
}
// Collectorをprometheusライブラリに登録
if err := prometheus.Register(exporter); err != nil {
log.Fatal(err)
}
// 定期的にメトリクスを更新する
go exporter.AutoUpdate()
// HTTPでメトリクスを出力
http.HandleFunc("/", indexPage)
http.Handle("/metrics", promhttp.Handler())
log.Fatal(http.ListenAndServe(":"+*port, nil))
}