現在主流的配置文件格式有這么幾種,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 main import ( "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)) }
