还是那个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