Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

AdapterFile

AdapterFile是框架默认的配置管理实现方式,基于文件的配置加载和读取。

通过g.Cfg单例对象使用

大部分场景下,我们可以通过框架已经封装好的g.Cfg单例对象来便捷使用基于文件的配置管理实现。例如:

config.yaml

Code Block
languageyml
server:
  address:     ":8888"
  openapiPath: "/api.json"
  swaggerPath: "/swagger"
  dumpRouterMap: false

database:
  default:
    link:  "mysql:root:12345678@tcp(127.0.0.1:3306)/test"
    debug:  true

main.go

Code Block
languagego
package main

import (
	"fmt"

	"github.com/gogf/gf/v2/frame/g"
	"github.com/gogf/gf/v2/os/gctx"
)

func main() {
	var ctx = gctx.New()
	fmt.Println(g.Cfg().MustGet(ctx, "server.address").String())
	fmt.Println(g.Cfg().MustGet(ctx, "database.default").Map())
}

运行后,终端输出:

Code Block
languagexml
:8888
map[debug:true link:mysql:root:12345678@tcp(127.0.0.1:3306)/test]

 通过gcfg.NewWithAdapter使用

 我们也可以通过配置组件的NewWithAdapter方法来创建一个基于给定Adapter的配置管理对象,当然,在这里我们给一个AdapterFile接口对象。


config.yaml

Code Block
languageyml
server:
  address:     ":8888"
  openapiPath: "/api.json"
  swaggerPath: "/swagger"
  dumpRouterMap: false

database:
  default:
    link:  "mysql:root:12345678@tcp(127.0.0.1:3306)/test"
    debug:  true

main.go

Code Block
languagego
package main

import (
	"fmt"

	"github.com/gogf/gf/v2/os/gcfg"
	"github.com/gogf/gf/v2/os/gctx"
)

func main() {
	var ctx = gctx.New()
	adapter, err := gcfg.NewAdapterFile("config")
	if err != nil {
		panic(err)
	}
	config := gcfg.NewWithAdapter(adapter)
	fmt.Println(config.MustGet(ctx, "server.address").String())
	fmt.Println(config.MustGet(ctx, "database.default").Map())
}

运行后,终端输出:

Code Block
languagexml
:8888
map[debug:true link:mysql:root:12345678@tcp(127.0.0.1:3306)/test]


Panel
titleContent Menu

Table of Contents