前言
虽然夜莺项目内置了一些通用的通知渠道,不过并不是很好看,打算diy一下,通过官网这篇介绍夜莺和自定义告警通知脚本如何联动?很容易就可以添加自定义通知模板,可以看到自定义通知模板是go template,我之前并没有了解过怎么写,所以本文记录一下我在学习go temple的内容。顺便吐槽一下,目前添加完自定义渠道后,调试时候还挺麻烦。通过代码可以看到夜莺在通知模版初始化过程中,当判断有渠道名称(文件名)已经在数据库中,导致文件内容的并没有更新,所以目前我做法是通过删除表数据来更新文件内容。
使用go template
当你第一次使用temlate时候一定和我一样也会困惑1秒选择哪包,ide会提示有多个包,一个是 text/template
另一个是 html/template
。根据我目前了解,它们两者都是一样的接口,不过 html/template
生成的输出内容,更适合用在 html 中(数据被输出为应编码的纯文本),可以防止代码注入导致的安全问题,可以理解为html/template
封装了text/template
,并针对html的输出常见做了优化,能够根据模版自动解析讲数据填充合适内容(HTML, CSS, JavaScript, 或者 URIs)。
// 定义模板
tepl := "Hello {
{ . }}"
// 解析模板
tmpl, err := template.New("test").Parse(tepl)
data := `world
<a>hello</a>
`
//渲染模版
err = tmpl.Execute(os.Stdout, data)
上面这段代码可以看出template一个最简单的使用,通过分隔符{
{
,}}
来包裹模版的数据,分文三部分完成解析:
-
- 定义模板文件
-
- 解析模板文件
-
- 渲染模板文件
你可以在playground中简单尝试看看引用两种包分别得到的输出结果。另外分隔符默认值是可通过Delims(left, right string)来自定义:)。
- 渲染模板文件
定义模版
可以从上面例子猜到在template的两个分隔符之间.
代表的就是当前值,这个值可以是哪些呢?简单来说类似打印函数fmt.Print()
,数值,字符串,slice(切片),map,struct等等。简单的值很容易,但是实际场景中我们需要传入更复杂的数据结构,它们的例子如下