W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
對(duì)于日志輸出即時(shí)性要求不高的內(nèi)容,可以通過異步的方式輸出日志,異步輸出使得日志打印調(diào)用可立即返回,因此效率較高。?glog
?當(dāng)然支持異步輸出特性,并且內(nèi)部使用了?goroutine
?池來管理異步日志打印任務(wù),可以充分的降低對(duì)資源的占用率。
異步輸出可以通過日志對(duì)象的?SetAsync
?/?SetFlags
?方法,或者通過鏈?zhǔn)讲僮?Async
?方法實(shí)現(xiàn)。但是需要注意的是,如果通過對(duì)象設(shè)置方法設(shè)置異步輸出,那么后續(xù)所有的日志輸出都將是異步的;如果是通過鏈?zhǔn)讲僮鬏敵觯敲磧H對(duì)當(dāng)前日志輸出為異步。
如果對(duì)于同一個(gè)文件日志輸出既采用了同步打印,也采用了異步打印,注意日志文件的內(nèi)容可能會(huì)出現(xiàn)亂序問題,這種情況應(yīng)當(dāng)盡量避免。
我們來看一個(gè)使用?SetAsync
?方法實(shí)現(xiàn)異步打印的示例。
package main
import (
"context"
"time"
"github.com/gogf/gf/v2/frame/g"
)
func main() {
ctx := context.TODO()
g.Log().SetAsync(true)
for i := 0; i < 10; i++ {
g.Log().Print(ctx, "async log", i)
}
}
執(zhí)行后,可以發(fā)現(xiàn)終端什么內(nèi)容也沒有輸出,因?yàn)槿罩据敵龅漠惒降?,該示例在日志?nèi)容還沒有輸出之前就退出了。因此,我們可以稍做改進(jìn)如下:
package main
import (
"context"
"time"
"github.com/gogf/gf/v2/frame/g"
)
func main() {
ctx := context.TODO()
g.Log().SetAsync(true)
for i := 0; i < 10; i++ {
g.Log().Print(ctx, "async log", i)
}
time.Sleep(time.Second)
}
執(zhí)行后,終端輸出結(jié)果為:
2019-06-02 15:44:21.399 async log 0
2019-06-02 15:44:21.399 async log 1
2019-06-02 15:44:21.399 async log 2
2019-06-02 15:44:21.399 async log 3
2019-06-02 15:44:21.399 async log 4
2019-06-02 15:44:21.399 async log 5
2019-06-02 15:44:21.399 async log 6
2019-06-02 15:44:21.399 async log 7
2019-06-02 15:44:21.399 async log 8
2019-06-02 15:44:21.399 async log 9
使用鏈?zhǔn)讲僮鞅容^簡單。
package main
import (
"context"
"time"
"github.com/gogf/gf/v2/frame/g"
)
func main() {
ctx := context.TODO()
for i := 0; i < 10; i++ {
g.Log().Print(ctx, "async log", i)
}
g.Log().Print(ctx, "normal log")
g.Log().Print(ctx, "normal log")
g.Log().Print(ctx, "normal log")
time.Sleep(time.Second)
}
執(zhí)行后,終端輸出結(jié)果為:
2022-01-05 15:00:44.101 normal log
2022-01-05 15:00:44.101 async log 0
2022-01-05 15:00:44.101 async log 1
2022-01-05 15:00:44.101 async log 2
2022-01-05 15:00:44.101 async log 3
2022-01-05 15:00:44.101 async log 4
2022-01-05 15:00:44.101 async log 5
2022-01-05 15:00:44.101 async log 6
2022-01-05 15:00:44.101 async log 7
2022-01-05 15:00:44.101 async log 8
2022-01-05 15:00:44.101 async log 9
2022-01-05 15:00:44.101 normal log
2022-01-05 15:00:44.103 normal log
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: