现在主流的配置文件格式有这么几种,xml、yaml、config… xml就算了,太挫了,太土, 太繁琐… config 就是mysql,apache my.cnf的那种格式,这个格式适合功能分层,不适合写同级的配置端.
yaml是我最喜欢的配置格式,像ansible、saltstack、puppet都是使用yaml来做配置格式.
我在以前的公司开发的平台系统用的都是yaml格式. 简练,充满张力 !!!
我在python中只用yaml格式,在golang中当然也会优先选择这门配置语言. 又废话了.
话说golang关于yaml的库包在github中能找到好几个,但有些yaml功能包光看那奇葩的库包名就觉得不靠谱. 说到这里我又要喷golang的库包管理了,你丫就不能整个类似pypi服务… 说实话我真的害怕作者提交新功能,然后导致整个库包都不能使用。
这个是我使用的go yaml包,star关注值还不低 . https://github.com/go-yaml/yaml
废话不多说了,直接上yaml的例子。 我在代码里参杂了yaml.v2库的使用方法.
跟golang处理json结构一样,yaml的格式也是需要用struct结构体反射的. struct里的字段首字母最好是大写,yaml string到时无所谓.
#http://xiaorui.cc
package mainimport (
"fmt"
"log" "gopkg.in/yaml.v2"
)var data = `
blog: xiaorui.cc
best_authors: ["fengyun","lee","park"]
desc:
counter: 521
plist: [3, 4]
`type T struct {
Blog string
Authors []string `yaml:"best_authors,flow"`
Desc struct {
Counter int `yaml:"Counter"`
Plist []int `yaml:",flow"`
}
}func main() {
t := T{}
//把yaml形式的字符串解析成struct类型
err := yaml.Unmarshal([]byte(data), &t)
//修改struct里面的记录
t.Blog = "this is Blog"
t.Authors = append(t.Authors, "myself")
t.Desc.Counter = 99
fmt.Printf("--- t:\n%v\n\n", t)
//转换成yaml字符串类型
d, err := yaml.Marshal(&t)
if err != nil {
log.Fatalf("error: %v", err)
}
fmt.Printf("--- t dump:\n%s\n\n", string(d))
}