如何結合 cobra 和 klog
我有一個專案需要使用cobra
和klog
來產生可執行檔並列印日誌並保留。
首先我測試了一下,使用下面的klog
可以將日誌同時輸出到terminal和file
。
package main import ( "flag" "k8s.io/klog" ) func init() { var fs flag.flagset klog.initflags(&fs) fs.set("logtostderr", "false") fs.set("log_file_max_size", "100") fs.set("log_file", "/home/test/workspace/klogfile/test.log") fs.set("alsologtostderr", "true") } func main() { defer klog.flush() klog.info("info") klog.warning("warning") klog.error("error") }
檔案/home/test/workspace/klogfile/test.log
的內容如下
log file created at: 2023/04/06 16:46:07 running on machine: s52 binary: built with gc go1.16.12 for linux/amd64 log line format: [iwef]mmdd hh:mm:ss.uuuuuu threadid file:line] msg i0406 16:46:07.751183 13512 main.go:20] info w0406 16:46:07.751594 13512 main.go:21] warning e0406 16:46:07.751629 13512 main.go:22] error
然後我嘗試基於k8s style
添加到cobra
package main import ( "flag" "github.com/spf13/cobra" "k8s.io/klog" ) var ( str = "hello world" ) func newcommand() *cobra.command { cmd := &cobra.command{ use: "echo", short: "use klog with cobra", long: "use klog together with cobra.", run: func(cmd *cobra.command, args []string) { run() }, } klog.initflags(flag.commandline) cmd.flags().addgoflagset(flag.commandline) cmd.flags().sortflags = false cmd.flags().stringvar(&str, "str", str, "string to print") return cmd } func run() { defer klog.flush() klog.infof("running, str:%s", str) } func main() { if err := newcommand().execute(); err != nil { klog.fatalf("root cmd execute failed, err=%v", err) } }
我可以透過--help
列印出required日誌選項
,但是當我重寫它們以實現上例中的儲存到檔案時,僅將輸出輸出到終端機而不是輸出到檔案< /strong>
# go run main2.go --logtostderr false --log_file_max_size "100" --alsologtostderr true --log_file "/home/test/workspace/klogfile/test2.log" I0406 16:52:57.479455 15217 cobra_klog.go:34] Running, str:hello world
請問我哪裡的缺少必要的程式碼
,如果有請告訴我如何修改,謝謝!
正確答案
你的程式碼沒有任何問題。唯一的問題是您必須使用 -flag=false
表單來關閉布林標誌(請參閱 命令列標誌語法)。
嘗試此指令(以 --logtostderr=false
取代 --logtostderr false
):
go run main2.go --logtostderr=false --log_file_max_size "100" --alsologtostderr true --log_file "/home/test/workspace/klogfile/test2.log"
順便說一句,我認為 --log_file_max_size "100"
可以簡化為 --log_file_max_size 100
。
更新:
減少 klog 暴露的標誌:
package main import ( "flag" "github.com/spf13/cobra" "k8s.io/klog" ) var ( str = "hello world" + logFile string ) func NewCommand() *cobra.Command { + var fs flag.FlagSet + klog.InitFlags(&fs) cmd := &cobra.Command{ Use: "echo", Short: "use klog with cobra", Long: "Use klog together with cobra.", Run: func(cmd *cobra.Command, args []string) { + fs.Set("logtostderr", "false") + fs.Set("log_file", logFile) Run() }, } - klog.InitFlags(flag.CommandLine) - cmd.Flags().AddGoFlagSet(flag.CommandLine) cmd.Flags().SortFlags = false cmd.Flags().StringVar(&str, "str", str, "string to print") + cmd.Flags().StringVar(&logFile, "log_file", "", "If non-empty, use this log file") return cmd } func Run() { defer klog.Flush() klog.Infof("Running, str:%s", str) } func main() { if err := NewCommand().Execute(); err != nil { klog.Fatalf("root cmd execute failed, err=%v", err) } }
以上是如何結合 cobra 和 klog的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

OpenSSL,作為廣泛應用於安全通信的開源庫,提供了加密算法、密鑰和證書管理等功能。然而,其歷史版本中存在一些已知安全漏洞,其中一些危害極大。本文將重點介紹Debian系統中OpenSSL的常見漏洞及應對措施。 DebianOpenSSL已知漏洞:OpenSSL曾出現過多個嚴重漏洞,例如:心臟出血漏洞(CVE-2014-0160):該漏洞影響OpenSSL1.0.1至1.0.1f以及1.0.2至1.0.2beta版本。攻擊者可利用此漏洞未經授權讀取服務器上的敏感信息,包括加密密鑰等。

Go語言中用於浮點數運算的庫介紹在Go語言(也稱為Golang)中,進行浮點數的加減乘除運算時,如何確保精度是�...

Go爬蟲Colly中的Queue線程問題探討在使用Go語言的Colly爬蟲庫時,開發者常常會遇到關於線程和請求隊列的問題。 �...

後端學習路徑:從前端轉型到後端的探索之旅作為一名從前端開發轉型的後端初學者,你已經有了nodejs的基礎,...

本文討論了GO編程中的GO FMT命令,該命令將代碼格式化以遵守官方樣式準則。它突出了GO FMT在維持代碼一致性,可讀性和降低樣式辯論方面的重要性。 FO的最佳實踐

本文介紹在Debian系統下監控PostgreSQL數據庫的多種方法和工具,助您全面掌握數據庫性能監控。一、利用PostgreSQL內置監控視圖PostgreSQL自身提供多個視圖用於監控數據庫活動:pg_stat_activity:實時展現數據庫活動,包括連接、查詢和事務等信息。 pg_stat_replication:監控複製狀態,尤其適用於流複製集群。 pg_stat_database:提供數據庫統計信息,例如數據庫大小、事務提交/回滾次數等關鍵指標。二、借助日誌分析工具pgBadg
