还是那个golang监控agent那些事情,现在功能差不多了,唯独缺少信号处理及daemon服务化。 程序写的差不多了,但是这配置文件咋整? 难道把这些常亮要写在.go文件里面?
我对golang还没能理解到无缝reload的模式… 如果是写在配置文件就很简单了,有个goroutine notify监控配置文件或者是以接受信号的方式重新初始化任务。
现在主流的配置文件格式有这么几种,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)) }
END… 关于golang yaml使用方法原文链接. http://xiaorui.cc/?p=3012