Golang記錄、計(jì)算函數(shù)執(zhí)行耗時(shí)、運(yùn)行時(shí)間的一個(gè)簡(jiǎn)單方法
先寫一個(gè)公共函數(shù), 比如在 common 包下有這么一個(gè)方法:
// 寫超時(shí)警告日志 通用方法
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)
}
}
這個(gè)函數(shù)的幾個(gè)參數(shù)說(shuō)明如下:
tag、detailed 表示超時(shí)發(fā)生位置的兩個(gè)字符串參數(shù)。
start 程序開始執(zhí)行的時(shí)間
timeLimit 函數(shù)執(zhí)行超時(shí)閥值,單位是秒。
使用時(shí),在每個(gè)函數(shù)的第一行有下面一段代碼就行了:
//
func Save函數(shù)名(…) (…) {
// 如果這個(gè)方法執(zhí)行超時(shí)3秒,則會(huì)記錄日志
defer common.TimeoutWarning("SaveAppLogMain", "Total", time.Now(), float64(3))
// … 函數(shù)自身的邏輯。
}
相關(guān)文章
go語(yǔ)言通過(guò)反射獲取和設(shè)置結(jié)構(gòu)體字段值的方法
這篇文章主要介紹了go語(yǔ)言通過(guò)反射獲取和設(shè)置結(jié)構(gòu)體字段值的方法,實(shí)例分析了Go語(yǔ)言反射的使用技巧,需要的朋友可以參考下2015-03-03
GoLang中的互斥鎖Mutex和讀寫鎖RWMutex使用教程
RWMutex是一個(gè)讀/寫互斥鎖,在某一時(shí)刻只能由任意數(shù)量的reader持有或者一個(gè)writer持有。也就是說(shuō),要么放行任意數(shù)量的reader,多個(gè)reader可以并行讀;要么放行一個(gè)writer,多個(gè)writer需要串行寫2023-01-01
Go在GoLand中引用github.com中的第三方包具體步驟
這篇文章主要給大家介紹了關(guān)于Go在GoLand中引用github.com中第三方包的具體步驟,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Go具有一定的參考價(jià)值,需要的朋友可以參考下2024-01-01
使用go語(yǔ)言實(shí)現(xiàn)cors中間件
CORS是一種瀏覽器安全機(jī)制,用于控制在Web應(yīng)用程序中不同源(Origin)之間的資源共享,本文將給大家介紹如何使用go語(yǔ)言實(shí)現(xiàn)cors中間件,文中有詳細(xì)的代碼示例供大家參考,需要的朋友可以參考下2023-09-09
golang讀取yaml配置文件的方法實(shí)現(xiàn)
本文主要介紹了golang讀取yaml配置文件的方法實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-10-10
Go實(shí)現(xiàn)整合Logrus實(shí)現(xiàn)日志打印
這篇文章主要介紹了Go實(shí)現(xiàn)整合Logrus實(shí)現(xiàn)日志打印,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07
Golang動(dòng)態(tài)數(shù)組的實(shí)現(xiàn)示例
動(dòng)態(tài)數(shù)組能自動(dòng)調(diào)整大小,與靜態(tài)數(shù)組不同,其大小不固定,可根據(jù)需求變化,實(shí)現(xiàn)通常依賴于數(shù)據(jù)結(jié)構(gòu)如鏈表或數(shù)組加額外信息,本文就來(lái)介紹一下Golang動(dòng)態(tài)數(shù)組的實(shí)現(xiàn)示例,感興趣的可以了解一下2024-10-10

