Like Prometheus, but for logs.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
loki/cmd/logql-analyzer/main.go

52 lines
1.3 KiB

package main
import (
"flag"
"net/http"
"github.com/go-kit/log/level"
"github.com/gorilla/mux"
"github.com/prometheus/client_golang/prometheus"
"github.com/weaveworks/common/server"
"github.com/grafana/loki/pkg/logqlanalyzer"
util_log "github.com/grafana/loki/pkg/util/log"
)
func main() {
cfg := getConfig()
util_log.InitLogger(&server.Config{
LogLevel: cfg.LogLevel,
}, prometheus.DefaultRegisterer, true, false)
s, err := createServer(cfg)
if err != nil {
level.Error(util_log.Logger).Log("msg", "error while creating the server", "err", err)
}
err = s.Run()
defer s.Shutdown()
if err != nil {
level.Error(util_log.Logger).Log("msg", "error while running the server", "err", err)
}
}
func getConfig() server.Config {
cfg := server.Config{}
cfg.RegisterFlags(flag.CommandLine)
flag.Parse()
return cfg
}
func createServer(cfg server.Config) (*server.Server, error) {
s, err := server.New(cfg)
if err != nil {
return nil, err
}
s.HTTP.Use(mux.CORSMethodMiddleware(s.HTTP))
s.HTTP.Use(logqlanalyzer.CorsMiddleware())
s.HTTP.Handle("/api/logql-analyze", &logqlanalyzer.LogQLAnalyzeHandler{}).Methods(http.MethodPost, http.MethodOptions)
s.HTTP.HandleFunc("/ready", func(w http.ResponseWriter, _ *http.Request) {
http.Error(w, "ready", http.StatusOK)
}).Methods(http.MethodGet)
return s, err
}