main.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. "io/ioutil"
  6. "os"
  7. "os/signal"
  8. "path/filepath"
  9. "runtime"
  10. "runtime/trace"
  11. "strconv"
  12. "syscall"
  13. "time"
  14. "net/http"
  15. _ "net/http/pprof"
  16. "github.com/grafana/grafana/pkg/log"
  17. "github.com/grafana/grafana/pkg/models"
  18. "github.com/grafana/grafana/pkg/services/sqlstore"
  19. "github.com/grafana/grafana/pkg/setting"
  20. _ "github.com/grafana/grafana/pkg/services/alerting/conditions"
  21. _ "github.com/grafana/grafana/pkg/services/alerting/notifiers"
  22. _ "github.com/grafana/grafana/pkg/tsdb/graphite"
  23. _ "github.com/grafana/grafana/pkg/tsdb/influxdb"
  24. _ "github.com/grafana/grafana/pkg/tsdb/mqe"
  25. _ "github.com/grafana/grafana/pkg/tsdb/mysql"
  26. _ "github.com/grafana/grafana/pkg/tsdb/opentsdb"
  27. _ "github.com/grafana/grafana/pkg/tsdb/prometheus"
  28. _ "github.com/grafana/grafana/pkg/tsdb/testdata"
  29. )
  30. var version = "4.1.0"
  31. var commit = "NA"
  32. var buildstamp string
  33. var build_date string
  34. var configFile = flag.String("config", "", "path to config file")
  35. var homePath = flag.String("homepath", "", "path to grafana install/home path, defaults to working directory")
  36. var pidFile = flag.String("pidfile", "", "path to pid file")
  37. var exitChan = make(chan int)
  38. func init() {
  39. runtime.GOMAXPROCS(runtime.NumCPU())
  40. }
  41. func main() {
  42. v := flag.Bool("v", false, "prints current version and exits")
  43. profile := flag.Bool("profile", false, "Turn on pprof profiling")
  44. profilePort := flag.Int("profile-port", 6060, "Define custom port for profiling")
  45. flag.Parse()
  46. if *v {
  47. fmt.Printf("Version %s (commit: %s)\n", version, commit)
  48. os.Exit(0)
  49. }
  50. if *profile {
  51. runtime.SetBlockProfileRate(1)
  52. go func() {
  53. http.ListenAndServe(fmt.Sprintf("localhost:%d", *profilePort), nil)
  54. }()
  55. f, err := os.Create("trace.out")
  56. if err != nil {
  57. panic(err)
  58. }
  59. defer f.Close()
  60. err = trace.Start(f)
  61. if err != nil {
  62. panic(err)
  63. }
  64. defer trace.Stop()
  65. }
  66. buildstampInt64, _ := strconv.ParseInt(buildstamp, 10, 64)
  67. if buildstampInt64 == 0 {
  68. buildstampInt64 = time.Now().Unix()
  69. }
  70. setting.BuildVersion = version
  71. setting.BuildCommit = commit
  72. setting.BuildStamp = buildstampInt64
  73. server := NewGrafanaServer()
  74. server.Start()
  75. }
  76. func initRuntime() {
  77. err := setting.NewConfigContext(&setting.CommandLineArgs{
  78. Config: *configFile,
  79. HomePath: *homePath,
  80. Args: flag.Args(),
  81. })
  82. if err != nil {
  83. log.Fatal(3, err.Error())
  84. }
  85. logger := log.New("main")
  86. logger.Info("Starting Grafana", "version", version, "commit", commit, "compiled", time.Unix(setting.BuildStamp, 0))
  87. setting.LogConfigurationInfo()
  88. }
  89. func initSql() {
  90. sqlstore.NewEngine()
  91. sqlstore.EnsureAdminUser()
  92. }
  93. func writePIDFile() {
  94. if *pidFile == "" {
  95. return
  96. }
  97. // Ensure the required directory structure exists.
  98. err := os.MkdirAll(filepath.Dir(*pidFile), 0700)
  99. if err != nil {
  100. log.Fatal(3, "Failed to verify pid directory", err)
  101. }
  102. // Retrieve the PID and write it.
  103. pid := strconv.Itoa(os.Getpid())
  104. if err := ioutil.WriteFile(*pidFile, []byte(pid), 0644); err != nil {
  105. log.Fatal(3, "Failed to write pidfile", err)
  106. }
  107. }
  108. func listenToSystemSignals(server models.GrafanaServer) {
  109. signalChan := make(chan os.Signal, 1)
  110. ignoreChan := make(chan os.Signal, 1)
  111. code := 0
  112. signal.Notify(ignoreChan, syscall.SIGHUP)
  113. signal.Notify(signalChan, os.Interrupt, os.Kill, syscall.SIGTERM)
  114. select {
  115. case sig := <-signalChan:
  116. // Stops trace if profiling has been enabled
  117. trace.Stop()
  118. server.Shutdown(0, fmt.Sprintf("system signal: %s", sig))
  119. case code = <-exitChan:
  120. server.Shutdown(code, "startup error")
  121. }
  122. }