av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

創(chuàng)新互聯(lián)GoFrame教程:GoFrame日志組件-異步輸出

對于日志輸出即時性要求不高的內(nèi)容,可以通過異步的方式輸出日志,異步輸出使得日志打印調(diào)用可立即返回,因此效率較高。?glog?當然支持異步輸出特性,并且內(nèi)部使用了?GOroutine?池來管理異步日志打印任務,可以充分的降低對資源的占用率。

創(chuàng)新互聯(lián)公司主營義安網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,手機APP定制開發(fā),義安h5微信小程序開發(fā)搭建,義安網(wǎng)站營銷推廣歡迎義安等地區(qū)企業(yè)咨詢

異步輸出可以通過日志對象的?SetAsync?/?SetFlags?方法,或者通過鏈式操作?Async?方法實現(xiàn)。但是需要注意的是,如果通過對象設(shè)置方法設(shè)置異步輸出,那么后續(xù)所有的日志輸出都將是異步的;如果是通過鏈式操作輸出,那么僅對當前日志輸出為異步。

如果對于同一個文件日志輸出既采用了同步打印,也采用了異步打印,注意日志文件的內(nèi)容可能會出現(xiàn)亂序問題,這種情況應當盡量避免。

SetAsync

我們來看一個使用?SetAsync?方法實現(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)容也沒有輸出,因為日志輸出的異步的,該示例在日志內(nèi)容還沒有輸出之前就退出了。因此,我們可以稍做改進如下:

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

Async鏈式操作

使用鏈式操作比較簡單。

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

名稱欄目:創(chuàng)新互聯(lián)GoFrame教程:GoFrame日志組件-異步輸出
文章網(wǎng)址:http://uogjgqi.cn/article/dhdsceg.html
掃二維碼與項目經(jīng)理溝通

我們在微信上24小時期待你的聲音

解答本文疑問/技術(shù)咨詢/運營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流