modularize

This commit is contained in:
Matej Kramny
2015-03-15 20:58:14 +01:00
parent 7b3d6eba89
commit 1cadc9b3b3
4 changed files with 110 additions and 58 deletions

8
cachet/cachet.go Normal file
View File

@@ -0,0 +1,8 @@
package cachet
import "os"
// apiUrl -> https://demo.cachethq.io/api
// apiToken -> qwertyuiop
var apiUrl = os.Getenv("CACHET_API")
var apiToken = os.Getenv("CACHET_TOKEN")

42
cachet/metrics.go Normal file
View File

@@ -0,0 +1,42 @@
package cachet
import (
"fmt"
"bytes"
"strconv"
"net/http"
"io/ioutil"
"encoding/json"
)
func SendMetric(metricId int, delay int64) {
jsonBytes, err := json.Marshal(&map[string]interface{}{
"value": delay,
})
if err != nil {
panic(err)
}
req, err := http.NewRequest("POST", apiUrl + "/metrics/" + strconv.Itoa(metricId) + "/points", bytes.NewBuffer(jsonBytes))
if err != nil {
panic(err)
}
req.Header.Set("Content-Type", "application/json")
req.Header.Set("X-Cachet-Token", apiToken)
client := &http.Client{}
resp, err := client.Do(req)
if err != nil {
panic(err)
}
defer resp.Body.Close()
body, _ := ioutil.ReadAll(resp.Body)
fmt.Println(strconv.Itoa(resp.StatusCode) + " " + string(body))
if resp.StatusCode != 200 {
fmt.Println("Could not log data point!")
}
}

49
cachet/monitor.go Normal file
View File

@@ -0,0 +1,49 @@
package cachet
import (
"fmt"
"time"
"net/http"
)
const timeout = time.Duration(time.Second)
type Monitor struct {
Url string `json:"url"`
MetricId int `json:"metric_id"`
}
func (monitor *Monitor) Run() {
reqStart := getMs()
err := monitor.doRequest()
lag := getMs() - reqStart
failed := false
if err != nil {
failed = true
}
if failed == true {
fmt.Println("Req failed")
}
SendMetric(1, lag)
}
func (monitor *Monitor) doRequest() error {
client := &http.Client{
Timeout: timeout,
}
resp, err := client.Get(monitor.Url) // http://127.0.0.1:1337
if err != nil {
return err
}
defer resp.Body.Close()
return nil
}
func getMs() int64 {
return time.Now().UnixNano() / int64(time.Millisecond)
}

69
main.go
View File

@@ -1,69 +1,22 @@
package main package main
import ( import (
"fmt"
// "time"
"net/http"
"bytes"
"io/ioutil"
"encoding/json"
"time" "time"
"./cachet"
) )
const timeout = time.Duration(time.Second)
func main() { func main() {
monitors := []cachet.Monitor{
cachet.Monitor{
Url: "https://nodegear.io/ping",
MetricId: 1,
},
}
ticker := time.NewTicker(time.Second) ticker := time.NewTicker(time.Second)
for _ = range ticker.C { for _ = range ticker.C {
reqStart := time.Now().UnixNano() / int64(time.Millisecond) for _, monitor := range monitors {
doRequest() go monitor.Run()
reqEnd := time.Now().UnixNano() / int64(time.Millisecond) }
go sendMetric(reqEnd - reqStart)
} }
} }
func doRequest() error {
client := http.Client{
Timeout: timeout,
}
resp, err := client.Get("https://nodegear.io/ping") // http://127.0.0.1:1337
if err != nil {
return err
}
defer resp.Body.Close()
return nil
}
func sendMetric(delay int64) {
js := &map[string]interface{}{
"value": delay,
}
jsonBytes, err := json.Marshal(&js)
if err != nil {
panic(err)
}
req, err := http.NewRequest("POST", "https://demo.cachethq.io/api/metrics/1/points", bytes.NewBuffer(jsonBytes))
if err != nil {
panic(err)
}
req.Header.Set("Accept", "application/json")
req.Header.Set("Content-Type", "application/json")
req.Header.Set("X-Cachet-Token", "5wQt9MnJXmhnQsDI8Hmv")
client := &http.Client{}
resp, err := client.Do(req)
if err != nil {
panic(err)
}
defer resp.Body.Close()
body, _ := ioutil.ReadAll(resp.Body)
fmt.Println(string(body))
}