go-zero/core/conf/readme.md

59 lines
1.3 KiB
Markdown
Raw Normal View History

## How to use
1. Define a config structure, like below:
```go
2022-06-11 11:46:50 +08:00
type RestfulConf struct {
ServiceName string `json:",env=SERVICE_NAME"` // read from env automatically
Host string `json:",default=0.0.0.0"`
Port int
2022-06-13 19:39:59 +08:00
LogMode string `json:",options=[file,console]"`
Verbose bool `json:",optional"`
MaxConns int `json:",default=10000"`
MaxBytes int64 `json:",default=1048576"`
Timeout time.Duration `json:",default=3s"`
CpuThreshold int64 `json:",default=900,range=[0:1000)"`
}
```
2022-06-13 19:35:51 +08:00
2. Write the yaml, toml or json config file:
- yaml example
```yaml
# most fields are optional or have default values
port: 8080
logMode: console
# you can use env settings
maxBytes: ${MAX_BYTES}
```
2022-06-13 19:35:51 +08:00
- toml example
```toml
# most fields are optional or have default values
port = 8_080
logMode = "console"
2022-06-13 19:35:51 +08:00
# you can use env settings
maxBytes = "${MAX_BYTES}"
2022-06-13 19:35:51 +08:00
```
3. Load the config from a file:
```go
// exit on error
var config RestfulConf
conf.MustLoad(configFile, &config)
// or handle the error on your own
var config RestfulConf
if err := conf.Load(configFile, &config); err != nil {
log.Fatal(err)
}
// enable reading from environments
var config RestfulConf
conf.MustLoad(configFile, &config, conf.UseEnv())
```