【GoWeb开发实战】Beego的参数配置
Beego的参数配置
beego 目前支持 INI、XML、JSON、YAML 格式的配置文件解析,但是默认采用了 INI 格式解析,用户可以通过简单的配置就可以获得很大的灵活性。
一、参数配置
1.1 默认的参数配置
beego默认会解析当前应用下的conf/app.conf文件,通过这个文件你可以初始化很多 beego 的默认参数:
appname = beegoDemo httpport = 8080 runmode = dev
你也可以在配置文件中配置应用需要用的一些配置信息,例如下面所示的数据库信息:
mysqluser = "root" mysqlpass = "rootpass" mysqlurls = "127.0.0.1" mysqldb = "beego"
获取设置的配置信息:
beego.AppConfig.String("mysqluser") beego.AppConfig.String("mysqlpass") beego.AppConfig.String("mysqlurls") beego.AppConfig.String("mysqldb")
1.2 不同级别的配置
根据不同的运行环境,不同的配置,如开发环境,正式生产线上,配置不同。
在配置文件里面支持 section,可以有不同的 Runmode 的配置,默认优先读取 runmode 下的配置信息,例如下面的配置文件,我们可以把配置分成三份,比如dev,prod,test,在什么环境那么runmode就配置成什么,其他配置文件同理。解析的时候优先解析 runmode 下的配置,然后解析默认的配置。如下所示:
appname = beegoDemo runmode = dev [dev] httpport = 9527 [test] httpport = 5566 [prod] httpport = 8082
runmode 配置为dev那么监听的端口就是9527了。
读取不同模式下配置参数的方法是“模式::配置参数名”,比如:
beego.AppConfig.String("dev::mysqluser")
对于自定义的参数,需使用 beego.GetConfig(tpy, key string, defaultVal interface{}) 来获取指定 runmode 下的配置(需 1.4.0 以上版本),typ 为参数类型,key 为参数名, defaultVal 为默认值。
1.3 多个配置文件
INI 格式配置支持 include 方式,引用多个配置文件,例如下面的两个配置文件效果同上:
beegoDemo.conf
appname = beegoDemo httpaddr = "127.0.0.1" httpport = 9527 include "beegoDemo2.conff"
beegoDemo2.conf
runmode ="dev" autorender = false recoverpanic = false viewspath = "myview" [dev] httpport = 8080 [prod] httpport = 8081 [test] httpport = 8082
扩展
AppConfig 的方法如下:
Set(key, val string) error
String(key string) string
Strings(key string) []string
Int(key string) (int, error)
Int64(key string) (int64, error)
Bool(key string) (bool, error)
Float(key string) (float64, error)
DefaultString(key string, defaultVal string) string
DefaultStrings(key string, defaultVal []string)
DefaultInt(key string, defaultVal int) int
DefaultInt64(key string, defaultVal int64) int64
DefaultBool(key string, defaultVal bool) bool
DefaultFloat(key string, defaultVal float64) float64
DIY(key string) (interface{}, error)
GetSection(section string) (map[string]string, error)
SaveConfigFile(filename string) error