先写一个公共函数, 比如在 common 包下有这么一个方法:

// 写超时警告日志 通用方法

func TimeoutWarning(tag, detailed string, start time.Time, timeLimit float64) {dis := time.Now().Sub(start).Seconds()if dis > timeLimit {log.Warning(log.CENTER_COMMON_WARNING, tag, " detailed:", detailed, "TimeoutWarning using", dis, "s")//pubstr := fmt.Sprintf("%s count %v, using %f seconds", tag, count, dis)//stats.Publish(tag, pubstr)}}这个函数的几个参数说明如下:• tag、detailed 表示超时发生位置的两个字符串参数。
• start 程序开始执行的时间
• timeLimit  函数执行超时阀值,单位是秒。
使用时,在每个函数的第一行有下面一段代码就行了://
func Save函数名(…) (…) {// 如果这个方法执行超时3秒,则会记录日志defer common.TimeoutWarning("SaveAppLogMain", "Total", time.Now(), float64(3))
    // … 函数自身的逻辑。}
阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: go