国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Golang 結(jié)構(gòu)化日志包 log/slog 詳解(二):Handler

這篇具有很好參考價(jià)值的文章主要介紹了Golang 結(jié)構(gòu)化日志包 log/slog 詳解(二):Handler。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

上一篇文章介紹了推出 log/slog 包的背景、log/slog 包的簡(jiǎn)單介紹和使用,簡(jiǎn)單使用了 Info 函數(shù),例如:

package main

import (
	"log/slog"
)

func main() {
	slog.Info("hello", "標(biāo)題", "路多辛的博客")
}

這段代碼輸出的內(nèi)容如下:

2023/09/08 22:33:16 INFO hello 標(biāo)題=路多辛的博客

默認(rèn)情況下,輸出的日志格式是普通的 text 格式,這種格式并不是最適合日志系統(tǒng)的格式。日志系統(tǒng)一般采用 SON 格式或者 key=value 類(lèi)型的文本格式,log/slog?包也提供了對(duì)應(yīng)功能。

Handler

log/slog 包實(shí)現(xiàn)不同的輸出格式是使用 Handler 來(lái)實(shí)現(xiàn)的,除了默認(rèn)的?Handler,?還提供了以 JSON 格式輸出的 JSONHandler 和以 key=value 格式輸出的 TextHandler。如果要使用這兩種 Handler,需要顯式創(chuàng)建出來(lái),示例代碼如下:

package main

import (
	"log/slog"
	"os"
)

func main() {
	loggerText := slog.New(slog.NewTextHandler(os.Stderr, nil))
	loggerText.Info("hello", "標(biāo)題", "路多辛的博客")

	loggerJSON := slog.New(slog.NewJSONHandler(os.Stderr, nil))
	loggerJSON.Info("hello", "標(biāo)題", "路多辛的博客")
}

上述代碼分別創(chuàng)建了一個(gè)使用 TextHandler 的 Logger 實(shí)例和一個(gè)使用 JSONHandler 的 Logger 實(shí)例,運(yùn)行結(jié)果如下:

time=2023-09-09T20:17:11.845+08:00 level=INFO msg=hello 標(biāo)題=路多辛的博客
{"time":"2023-09-09T20:17:11.846302+08:00","level":"INFO","msg":"hello","標(biāo)題":"路多辛的博客"}

也可以實(shí)現(xiàn)自己的 Handler,關(guān)于這塊知識(shí)接下來(lái)的文章會(huì)專(zhuān)門(mén)介紹。

HandlerOption

創(chuàng)建 TextHandler 和 JSONHandler 對(duì)象時(shí)都可以接受 *HandlerOptions 類(lèi)型的參數(shù),用于設(shè)置日志級(jí)別、是否顯示日志調(diào)用的源文件和行信息以及在記錄屬性之前修改屬性。看個(gè)示例:

package main

import (
    "log/slog"
    "os"
)

func main() {
    opts := slog.HandlerOptions{
       AddSource: true,
    }
    loggerJSON := slog.New(slog.NewJSONHandler(os.Stderr, &opts))
    loggerJSON.Info("hello", "標(biāo)題", "路多辛的博客")
}

創(chuàng)建 JSONHandler 時(shí),設(shè)置顯示調(diào)用的源文件和行信息,運(yùn)行看下結(jié)果:

{"time":"2023-09-09T20:38:10.868172+08:00","level":"INFO","source":{"function":"main.main","file":"/Users/ning/projects/go/workspace/hello/bin.go","line":13},"msg":"hello","標(biāo)題":"路多辛的博客"}

可以看到通過(guò) Info 方法輸出的日志信息里面包含了打印日志的代碼文件以及在源代碼文件中的位置。

設(shè)置默認(rèn) Logger

可以通過(guò) SetDefault 函數(shù)設(shè)置默認(rèn)的?Logger 類(lèi)型,設(shè)置默認(rèn) Logger 后打印日志的頂級(jí)函數(shù),例如 Info、Warn、Error 等都會(huì)按照新的格式打印日志,看個(gè)示例:

package main

import (
	"log/slog"
	"os"
)

func main() {
	loggerJSON := slog.New(slog.NewJSONHandler(os.Stderr, &opts))
	slog.SetDefault(loggerJSON)
	slog.Info("hello", "標(biāo)題", "路多辛的博客")
}

運(yùn)行看下輸出結(jié)果:

{"time":"2023-09-09T21:14:15.213592+08:00","level":"INFO","msg":"hello","標(biāo)題":"路多辛的博客"}

可以看到,使用?SetDefault 函數(shù)將默認(rèn) Logger 設(shè)置為了?loggerJSON,再調(diào)用 Info 函數(shù)后,就按照 JSON 格式打印日志了。文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-703779.html

到了這里,關(guān)于Golang 結(jié)構(gòu)化日志包 log/slog 詳解(二):Handler的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • python序列化和結(jié)構(gòu)化數(shù)據(jù)詳解

    序列化和結(jié)構(gòu)化數(shù)據(jù)是計(jì)算機(jī)程序中非常重要的概念,它們的原理和應(yīng)用在許多應(yīng)用程序中都是必不可少的。Python作為一種高級(jí)編程語(yǔ)言,在序列化和結(jié)構(gòu)化數(shù)據(jù)方面提供了很多優(yōu)秀的解決方案。在本文中,我們將詳細(xì)介紹Python中序列化和結(jié)構(gòu)化數(shù)據(jù)的相關(guān)概念和應(yīng)用。 1.

    2024年02月08日
    瀏覽(28)
  • ElasticSearch核心詳解、文檔、查詢(xún)響應(yīng)、分頁(yè)、映射、結(jié)構(gòu)化查詢(xún)

    ElasticSearch核心詳解、文檔、查詢(xún)響應(yīng)、分頁(yè)、映射、結(jié)構(gòu)化查詢(xún)

    在Elasticsearch中,文檔以JSON格式進(jìn)行存儲(chǔ),可以是復(fù)雜的結(jié)構(gòu),如: 其中,card是一個(gè)復(fù)雜對(duì)象,嵌套的Card對(duì)象 元數(shù)據(jù)(metadata) ???????一個(gè)文檔不只有數(shù)據(jù)。它還包含了元數(shù)據(jù)(metadata)——關(guān)于文檔的信息。 三個(gè)必須的元數(shù)據(jù)節(jié)點(diǎn)是: index ???????索引(index)類(lèi)似于關(guān)

    2024年02月12日
    瀏覽(21)
  • 結(jié)構(gòu)化數(shù)據(jù)、非結(jié)構(gòu)化數(shù)據(jù)、半結(jié)構(gòu)化數(shù)據(jù)

    結(jié)構(gòu)化數(shù)據(jù)、非結(jié)構(gòu)化數(shù)據(jù)、半結(jié)構(gòu)化數(shù)據(jù)

    結(jié)構(gòu)化的數(shù)據(jù)一般是指可以使用關(guān)系型數(shù)據(jù)庫(kù)表示和存儲(chǔ),可以用二維表來(lái)邏輯表達(dá)實(shí)現(xiàn)的數(shù)據(jù)。例如:需要多少個(gè)屬性,每個(gè)屬性什么類(lèi)型,每個(gè)屬性的取值范圍等等,類(lèi)似下圖所示, 提前定義好了一個(gè)二維矩陣的元數(shù)據(jù) ,包含有列名稱(chēng)、列的類(lèi)型、列的約束等: ? 可見(jiàn)

    2024年02月09日
    瀏覽(93)
  • 第五章 結(jié)構(gòu)化設(shè)計(jì)

    第五章 結(jié)構(gòu)化設(shè)計(jì)

    一種軟件開(kāi)發(fā)活動(dòng),定義實(shí)現(xiàn)需求規(guī)約所需的軟件結(jié)構(gòu)。 結(jié)構(gòu)化設(shè)計(jì)分為: (1)總體設(shè)計(jì):確定系統(tǒng)的整體模塊結(jié)構(gòu),即系統(tǒng)實(shí)現(xiàn)所需要的軟件模塊以及這些模塊之間的調(diào)用關(guān)系。 (2)詳細(xì)設(shè)計(jì):詳細(xì)描述模塊。 體系結(jié)構(gòu)設(shè)計(jì)(MSD) 接口設(shè)計(jì) 數(shù)據(jù)設(shè)計(jì) 實(shí)現(xiàn)軟件設(shè)計(jì)的目標(biāo)對(duì)結(jié)

    2024年02月08日
    瀏覽(28)
  • elasticsearch結(jié)構(gòu)化查詢(xún)

    elasticsearch結(jié)構(gòu)化查詢(xún)

    在上一篇中我們介紹了DSL相關(guān)的知識(shí),接下來(lái)我們將會(huì)學(xué)習(xí)elasticsearch的結(jié)構(gòu)化查詢(xún),同時(shí)也實(shí)踐一下上一篇的DSL的查詢(xún)用法 從《Elasticsearch權(quán)威指南》上摘取部分解釋如下: 從上面的定義我們可以看出來(lái)結(jié)構(gòu)化查詢(xún)最重要的就是是否匹配么人并不是很關(guān)心相關(guān)性和分值計(jì)算。

    2024年02月01日
    瀏覽(30)
  • 【numpy基礎(chǔ)】--結(jié)構(gòu)化

    目前為止,介紹的 numpy 數(shù)組基本都是關(guān)于數(shù)值的,其實(shí), numpy 本身就是一個(gè)用于數(shù)值計(jì)算的基礎(chǔ)庫(kù)。 不過(guò),除了數(shù)值計(jì)算之外, numpy 也能夠支持 結(jié)構(gòu)化數(shù)組 。 numpy 的數(shù)組為了提高計(jì)算性能,要求數(shù)組的數(shù)據(jù)類(lèi)型要一致。 但是現(xiàn)實(shí)情況下,我們經(jīng)常遇到不是純數(shù)值的數(shù)組

    2024年02月12日
    瀏覽(29)
  • WPF 界面結(jié)構(gòu)化處理

    WPF 界面結(jié)構(gòu)化處理

    WPF 框架是開(kāi)源的,但是不能跨平臺(tái),可以使用MAUI,這個(gè)框架可以跨平臺(tái),WPF源碼可以在github上下載,下載地址:https://gitbub.com/dotnet/wpf。 框架結(jié)構(gòu) 如圖 XAML:eXtensible Application Markup Language的英文縮寫(xiě),相應(yīng)的中文名稱(chēng)為:可擴(kuò)展應(yīng)用程序標(biāo)記語(yǔ)言。 命名空間 默認(rèn) 映射:x/

    2024年02月13日
    瀏覽(32)
  • SQL:結(jié)構(gòu)化查詢(xún)語(yǔ)言

    SQL:結(jié)構(gòu)化查詢(xún)語(yǔ)言

    創(chuàng)建一張表并插入數(shù)據(jù): 以下常用函數(shù)以MySQL為例,其它數(shù)據(jù)庫(kù)類(lèi)似

    2024年02月06日
    瀏覽(30)
  • elasticsearch結(jié)構(gòu)化查詢(xún)(一)

    elasticsearch結(jié)構(gòu)化查詢(xún)(一)

    在上一篇中我們介紹了DSL相關(guān)的知識(shí),接下來(lái)我們將會(huì)學(xué)習(xí)elasticsearch的結(jié)構(gòu)化查詢(xún),同時(shí)也實(shí)踐一下上一篇的DSL的查詢(xún)用法 從《Elasticsearch權(quán)威指南》上摘取部分解釋如下: 從上面的定義我們可以看出來(lái)結(jié)構(gòu)化查詢(xún)最重要的就是是否匹配么人并不是很關(guān)心相關(guān)性和分值計(jì)算。

    2024年02月05日
    瀏覽(28)
  • 結(jié)構(gòu)化流的介紹

    結(jié)構(gòu)化流的介紹

    目錄 有界數(shù)據(jù)和無(wú)界數(shù)據(jù) 有界數(shù)據(jù) ?無(wú)界數(shù)據(jù) ?結(jié)構(gòu)化流 基本介紹 入門(mén)案例 結(jié)構(gòu)化流的編程模型 數(shù)據(jù)結(jié)構(gòu) 數(shù)據(jù)源(Source) File Source Kafka Source(Spark 和 Kafka 整合) 整合Kafka準(zhǔn)備工作 從kafka中讀取數(shù)據(jù) 流式處理 批處理 ?數(shù)據(jù)寫(xiě)入Kafka中 流式處理 批處理 有界數(shù)據(jù) 數(shù)據(jù)有固定的開(kāi)

    2024年01月15日
    瀏覽(29)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包