go-zero/core/service/serviceconf.go

74 lines
1.6 KiB
Go
Raw Normal View History

2020-07-26 17:09:05 +08:00
package service
import (
"log"
2020-08-08 16:40:10 +08:00
"github.com/tal-tech/go-zero/core/load"
"github.com/tal-tech/go-zero/core/logx"
"github.com/tal-tech/go-zero/core/prometheus"
"github.com/tal-tech/go-zero/core/stat"
"github.com/tal-tech/go-zero/core/trace"
2020-07-26 17:09:05 +08:00
)
const (
// DevMode means development mode.
DevMode = "dev"
// TestMode means test mode.
2020-07-26 17:09:05 +08:00
TestMode = "test"
2021-03-30 20:53:35 +08:00
// RtMode means regression test mode.
2021-03-30 20:45:55 +08:00
RtMode = "rt"
// PreMode means pre-release mode.
PreMode = "pre"
// ProMode means production mode.
ProMode = "pro"
2020-07-26 17:09:05 +08:00
)
// A ServiceConf is a service config.
2020-07-26 17:09:05 +08:00
type ServiceConf struct {
2021-09-05 22:43:15 +08:00
Name string
Log logx.LogConf
Mode string `json:",default=pro,options=dev|test|rt|pre|pro"`
MetricsUrl string `json:",optional"`
Prometheus prometheus.Config `json:",optional"`
Telemetry trace.Config `json:",optional"`
2020-07-26 17:09:05 +08:00
}
// MustSetUp sets up the service, exits on error.
2020-07-26 17:09:05 +08:00
func (sc ServiceConf) MustSetUp() {
if err := sc.SetUp(); err != nil {
log.Fatal(err)
}
}
// SetUp sets up the service.
2020-07-26 17:09:05 +08:00
func (sc ServiceConf) SetUp() error {
if len(sc.Log.ServiceName) == 0 {
sc.Log.ServiceName = sc.Name
}
if err := logx.SetUp(sc.Log); err != nil {
return err
}
sc.initMode()
prometheus.StartAgent(sc.Prometheus)
if len(sc.Telemetry.Name) == 0 {
sc.Telemetry.Name = sc.Name
}
trace.StartAgent(sc.Telemetry)
2020-07-26 17:09:05 +08:00
if len(sc.MetricsUrl) > 0 {
stat.SetReportWriter(stat.NewRemoteWriter(sc.MetricsUrl))
}
return nil
}
func (sc ServiceConf) initMode() {
switch sc.Mode {
2021-03-30 20:45:55 +08:00
case DevMode, TestMode, RtMode, PreMode:
2020-07-26 17:09:05 +08:00
load.Disable()
stat.SetReporter(nil)
}
}