main.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. "io/ioutil"
  6. "os"
  7. "os/signal"
  8. "path/filepath"
  9. "runtime"
  10. "strconv"
  11. "syscall"
  12. "time"
  13. "github.com/grafana/grafana/pkg/log"
  14. "github.com/grafana/grafana/pkg/models"
  15. "github.com/grafana/grafana/pkg/services/sqlstore"
  16. "github.com/grafana/grafana/pkg/setting"
  17. _ "github.com/grafana/grafana/pkg/services/alerting/conditions"
  18. _ "github.com/grafana/grafana/pkg/services/alerting/notifiers"
  19. _ "github.com/grafana/grafana/pkg/tsdb/graphite"
  20. _ "github.com/grafana/grafana/pkg/tsdb/prometheus"
  21. _ "github.com/grafana/grafana/pkg/tsdb/testdata"
  22. )
  23. var version = "3.1.0"
  24. var commit = "NA"
  25. var buildstamp string
  26. var build_date string
  27. var configFile = flag.String("config", "", "path to config file")
  28. var homePath = flag.String("homepath", "", "path to grafana install/home path, defaults to working directory")
  29. var pidFile = flag.String("pidfile", "", "path to pid file")
  30. var exitChan = make(chan int)
  31. func init() {
  32. runtime.GOMAXPROCS(runtime.NumCPU())
  33. }
  34. func main() {
  35. v := flag.Bool("v", false, "prints current version and exits")
  36. flag.Parse()
  37. if *v {
  38. fmt.Printf("Version %s (commit: %s)\n", version, commit)
  39. os.Exit(0)
  40. }
  41. buildstampInt64, _ := strconv.ParseInt(buildstamp, 10, 64)
  42. if buildstampInt64 == 0 {
  43. buildstampInt64 = time.Now().Unix()
  44. }
  45. setting.BuildVersion = version
  46. setting.BuildCommit = commit
  47. setting.BuildStamp = buildstampInt64
  48. server := NewGrafanaServer()
  49. server.Start()
  50. }
  51. func initRuntime() {
  52. err := setting.NewConfigContext(&setting.CommandLineArgs{
  53. Config: *configFile,
  54. HomePath: *homePath,
  55. Args: flag.Args(),
  56. })
  57. if err != nil {
  58. log.Fatal(3, err.Error())
  59. }
  60. logger := log.New("main")
  61. logger.Info("Starting Grafana", "version", version, "commit", commit, "compiled", time.Unix(setting.BuildStamp, 0))
  62. setting.LogConfigurationInfo()
  63. }
  64. func initSql() {
  65. sqlstore.NewEngine()
  66. sqlstore.EnsureAdminUser()
  67. }
  68. func writePIDFile() {
  69. if *pidFile == "" {
  70. return
  71. }
  72. // Ensure the required directory structure exists.
  73. err := os.MkdirAll(filepath.Dir(*pidFile), 0700)
  74. if err != nil {
  75. log.Fatal(3, "Failed to verify pid directory", err)
  76. }
  77. // Retrieve the PID and write it.
  78. pid := strconv.Itoa(os.Getpid())
  79. if err := ioutil.WriteFile(*pidFile, []byte(pid), 0644); err != nil {
  80. log.Fatal(3, "Failed to write pidfile", err)
  81. }
  82. }
  83. func listenToSystemSignals(server models.GrafanaServer) {
  84. signalChan := make(chan os.Signal, 1)
  85. code := 0
  86. signal.Notify(signalChan, os.Interrupt, os.Kill, syscall.SIGTERM)
  87. select {
  88. case sig := <-signalChan:
  89. server.Shutdown(0, fmt.Sprintf("system signal: %s", sig))
  90. case code = <-exitChan:
  91. server.Shutdown(code, "startup error")
  92. }
  93. }