-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
40 lines (32 loc) · 969 Bytes
/
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
package main
import (
"github.com/dinoba/gocker/collector"
config "github.com/dinoba/gocker/customconfig"
"github.com/dinoba/gocker/log"
"github.com/dinoba/gocker/storage"
)
func main() {
//Blocking channel
quit := make(chan bool)
logger := log.GetInstance()
log.WithPrefix(logger, "Starting", "[INFO]")
conf, err := config.GetInstance()
if err != nil {
logger.Fatal(err)
panic(err)
}
//read config file
elasticsearchhost := conf.GetString("storage.elasticsearchhost")
//kafkahost := conf.GetString("storage.kafkahost")
topic := conf.GetString("storage.topic") //kafka topic = Elasticsearch index
dockersToSkip := conf.GetString("skip.dockers_to_skip")
st, err := storage.GetStorageHandler("ELASTICSEARCH", elasticsearchhost, topic)
//st, err := storage.GetStorageHandler("KAFKA", kafkahost, topic)
col := collector.NewCollector(st, dockersToSkip)
err = col.CollectStats()
if err != nil {
logger.Fatal(err)
panic(err)
}
<-quit
}