婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > golang 輸出重定向:fmt Log,子進程Log,第三方庫logrus的詳解

golang 輸出重定向:fmt Log,子進程Log,第三方庫logrus的詳解

熱門標簽:杭州人工智能電銷機器人費用 赤峰電銷 地圖區域圖標注后導出 官渡電銷外呼管理系統怎么收費 谷歌美發店地圖標注 利用地圖標注位置 貴州電話智能外呼系統 400開頭電話怎樣申請 江蘇呼叫中心外呼系統有效果嗎

獨立 fmt Log輸出重定向

golang的fmt包的輸出函數 Println、Printf、PrintStack等,默認將打印輸出到os.Stdout、錯誤打印輸出到os.Stderr,os.Stdout 和 os.Stderr 默認值 /dev/stdout /dev/stderr 設備。

//代碼摘自:golang封裝包 -> /lib/golang/src/os
var (
 Stdin = NewFile(uintptr(syscall.Stdin), "/dev/stdin")
 Stdout = NewFile(uintptr(syscall.Stdout), "/dev/stdout")
 Stderr = NewFile(uintptr(syscall.Stderr), "/dev/stderr")
)

改變 os.Stdout 和 os.Stderr 值將輸出重定向。

下面代碼將fmt輸出重定向到/home/fmt.log文件:

 f, _ := os.OpenFile("/home/fmt.log", os.O_WRONLY|os.O_CREATE|os.O_SYNC|os.O_APPEND,0755)
 os.Stdout = f
 os.Stderr = f

golang 第三方包:logrusLog輸出重定向

logrus Log 默認輸出到 os.Stderr

 func New() *Logger {
 return Logger{
 Out: os.Stderr,
 Formatter: new(TextFormatter),
 Hooks: make(LevelHooks),
 Level: InfoLevel,
 }
}

logrus提供封裝方法重定向輸出流:SetOutput;

下面代碼將fmt輸出重定向到/home/fmt.log文件:

import (
 "github.com/Sirupsen/logrus"
)
 f, _ := os.OpenFile("/home/fmt.log", os.O_WRONLY|os.O_CREATE|os.O_SYNC|os.O_APPEND,0755)
 logrus.SetOutput(f)

子進程輸出從定向

上面兩種方法都是在程序內部加入代碼,改變進程輸出重定向輸出流。在linux shell 中我們可以使用 > 符號或者 >> 重定向標準輸出。

在golang語言中,可使用 os/exec 封裝函數啟動子進程,并可使用相關設置重定向子進程的標準輸出(影響 fmt 和 logrus 的默認設置)。

下面代碼將fmt輸出重定向到/home/exec.log文件;

 cmd := exec.Command(binary_name, args...)
 f, _ := os.OpenFile("/home/exec.log", os.O_WRONLY|os.O_CREATE|os.O_SYNC,0755)
 cmd.Stdout = f
 cmd.Stderr = f

補充:Go之第三方日志庫logrus使用

第三方日志庫logrus使用

日志是程序中必不可少的一個環節,由于Go語言內置的日志庫功能比較簡潔,我們在實際開發中通常會選擇使用第三方的日志庫來進行開發。本文介紹了logrus這個日志庫的基本使用。

logrus介紹

Logrus是Go(golang)的結構化logger,與標準庫logger完全API兼容。

它有以下特點:

完全兼容標準日志庫,擁有七種日志級別:Trace, Debug, Info, Warning, Error, Fataland Panic。

可擴展的Hook機制,允許使用者通過Hook的方式將日志分發到任意地方,如本地文件系統,logstash,elasticsearch或者mq等,或者通過Hook定義日志內容和格式等

可選的日志輸出格式,內置了兩種日志格式JSONFormater和TextFormatter,還可以自定義日志格式

Field機制,通過Filed機制進行結構化的日志記錄

線程安全

安裝

$ go get github.com/sirupsen/logrus

基本示例

使用Logrus最簡單的方法是簡單的包級導出日志程序:

package main 
import (
 log "github.com/sirupsen/logrus"
) 
func main() {
 log.WithFields(log.Fields{
  "animal": "dog",
 }).Info("一條舔狗出現了。")
}

進階示例

對于更高級的用法,例如在同一應用程序記錄到多個位置,你還可以創建logrus Logger的實例:

package main 
import (
 "os"
 "github.com/sirupsen/logrus"
) 
// 創建一個新的logger實例??梢詣摻ㄈ我舛鄠€。
var log = logrus.New() 
func main() {
 // 設置日志輸出為os.Stdout
 log.Out = os.Stdout
 
 // 可以設置像文件等任意`io.Writer`類型作為日志輸出
 // file, err := os.OpenFile("logrus.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
 // if err == nil {
 // log.Out = file
 // } else {
 // log.Info("Failed to log to file, using default stderr")
 // }
 
 log.WithFields(logrus.Fields{
  "animal": "dog",
  "size":  10,
 }).Info("一群舔狗出現了。")
}

日志級別

Logrus有七個日志級別:Trace, Debug, Info, Warning, Error, Fataland Panic。

log.Trace("Something very low level.")
log.Debug("Useful debugging information.")
log.Info("Something noteworthy happened!")
log.Warn("You should probably take a look at this.")
log.Error("Something failed but I'm not quitting.")
// 記完日志后會調用os.Exit(1)
log.Fatal("Bye.")
// 記完日志后會調用 panic()
log.Panic("I'm bailing.")

設置日志級別

你可以在Logger上設置日志記錄級別,然后它只會記錄具有該級別或以上級別任何內容的條目:

// 會記錄info及以上級別 (warn, error, fatal, panic)

log.SetLevel(log.InfoLevel)   

如果你的程序支持debug或環境變量模式,設置log.Level = logrus.DebugLevel會很有幫助。

字段

Logrus鼓勵通過日志字段進行謹慎的結構化日志記錄,而不是冗長的、不可解析的錯誤消息。

例如,區別于使用log.Fatalf("Failed to send event %s to topic %s with key %d"),你應該使用如下方式記錄更容易發現的內容:

log.WithFields(log.Fields{
 "event": event,
 "topic": topic,
 "key": key,
}).Fatal("Failed to send event")

WithFields的調用是可選的。

默認字段

通常,將一些字段始終附加到應用程序的全部或部分的日志語句中會很有幫助。例如,你可能希望始終在請求的上下文中記錄request_id和user_ip。

區別于在每一行日志中寫上log.WithFields(log.Fields{"request_id": request_id, "user_ip": user_ip}),你可以向下面的示例代碼一樣創建一個logrus.Entry去傳遞這些字段。

requestLogger := log.WithFields(log.Fields{"request_id": request_id, "user_ip": user_ip})
requestLogger.Info("something happened on that request") # will log request_id and user_ip
requestLogger.Warn("something not great happened")

日志條目

除了使用WithField或WithFields添加的字段外,一些字段會自動添加到所有日志記錄事中:

time:記錄日志時的時間戳

msg:記錄的日志信息

level:記錄的日志級別

Hooks

你可以添加日志級別的鉤子(Hook)。例如,向異常跟蹤服務發送Error、Fatal和Panic、信息到StatsD或同時將日志發送到多個位置,例如syslog。

Logrus配有內置鉤子。在init中添加這些內置鉤子或你自定義的鉤子:

import (
 log "github.com/sirupsen/logrus"
 "gopkg.in/gemnasium/logrus-airbrake-hook.v2" // the package is named "airbrake"
 logrus_syslog "github.com/sirupsen/logrus/hooks/syslog"
 "log/syslog"
) 
func init() {
 
 // Use the Airbrake hook to report errors that have Error severity or above to
 // an exception tracker. You can create custom hooks, see the Hooks section.
 log.AddHook(airbrake.NewHook(123, "xyz", "production"))
 
 hook, err := logrus_syslog.NewSyslogHook("udp", "localhost:514", syslog.LOG_INFO, "")
 if err != nil {
  log.Error("Unable to connect to local syslog daemon")
 } else {
  log.AddHook(hook)
 }
}
  

意:Syslog鉤子還支持連接到本地syslog(例如. “/dev/log” or “/var/run/syslog” or “/var/run/log”)。有關詳細信息,請查看syslog hook README。

格式化

logrus內置以下兩種日志格式化程序:

logrus.TextFormatter

logrus.JSONFormatter

還支持一些第三方的格式化程序,詳見項目首頁。

記錄函數名

如果你希望將調用的函數名添加為字段,請通過以下方式設置:

log.SetReportCaller(true)   

這會將調用者添加為”method”,如下所示:

{"animal":"penguin","level":"fatal","method":"github.com/sirupsen/arcticcreatures.migrate","msg":"a penguin swims by", "time":"2014-03-10 19:57:38.562543129 -0400 EDT"}   

注意:,開啟這個模式會增加性能開銷。

線程安全

默認的logger在并發寫的時候是被mutex保護的,比如當同時調用hook和寫log時mutex就會被請求,有另外一種情況,文件是以appending mode打開的, 此時的并發操作就是安全的,可以用logger.SetNoLock()來關閉它。

gin框架使用logrus

// a gin with logrus demo 
var log = logrus.New() 
func init() {
  // Log as JSON instead of the default ASCII formatter.
  log.Formatter = logrus.JSONFormatter{}
  // Output to stdout instead of the default stderr
  // Can be any io.Writer, see below for File example
  f, _ := os.Create("./gin.log")
  log.Out = f
  gin.SetMode(gin.ReleaseMode) // 設置gin框架模式 線上模式 不會在終端打印多余的日志信息
  gin.DefaultWriter = log.Out
  // Only log the warning severity or above.
  log.Level = logrus.InfoLevel
} 
func main() {
  // 創建一個默認的路由引擎
  r := gin.Default()
  // GET:請求方式;/hello:請求的路徑
  // 當客戶端以GET方法請求/hello路徑時,會執行后面的匿名函數
  r.GET("/hello", func(c *gin.Context) {
    log.WithFields(logrus.Fields{
      "animal": "walrus",
      "size":  10,
    }).Warn("A group of walrus emerges from the ocean")
    // c.JSON:返回JSON格式的數據
    c.JSON(200, gin.H{
      "message": "Hello world!",
    })
  })
  // 啟動HTTP服務,默認在0.0.0.0:8080啟動服務
  r.Run()
}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • 手把手教你導入Go語言第三方庫
  • golang gopm get -g -v 無法獲取第三方庫的解決方案
  • golang值類型轉換成[]uint8類型的操作
  • go 類型轉換方式(interface 類型的轉換)
  • Mongodb 利用mongoshell進行數據類型轉換的實現方法
  • Go語言string,int,int64 ,float之間類型轉換方法
  • GO語言類型轉換和類型斷言實例分析
  • Go 第三方庫之類型轉換問題

標簽:鷹潭 黔西 宜春 武漢 河池 松原 保定 泰安

巨人網絡通訊聲明:本文標題《golang 輸出重定向:fmt Log,子進程Log,第三方庫logrus的詳解》,本文關鍵詞  golang,輸出,重定向,fmt,Log,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang 輸出重定向:fmt Log,子進程Log,第三方庫logrus的詳解》相關的同類信息!
  • 本頁收集關于golang 輸出重定向:fmt Log,子進程Log,第三方庫logrus的詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国模少妇一区二区三区| 91国偷自产一区二区开放时间| 亚洲高清视频的网址| 亚洲国产视频在线| 免费在线观看日韩欧美| 国产91丝袜在线18| 色88888久久久久久影院野外| 欧美日韩dvd在线观看| 日韩一区二区三区av| 国产欧美日韩三区| 亚洲高清三级视频| 成人av在线网| 久久成人18免费观看| 97精品视频在线观看自产线路二| 欧美午夜电影一区| 久久综合色婷婷| 亚洲美女免费在线| 久久精品av麻豆的观看方式| 99免费精品在线| 日韩欧美中文字幕公布| 国产精品欧美综合在线| 视频一区二区三区在线| 成人av影视在线观看| 欧美性xxxxx极品少妇| 国产日产欧产精品推荐色| 亚洲观看高清完整版在线观看| 韩国视频一区二区| 欧美视频完全免费看| 国产清纯在线一区二区www| 婷婷综合久久一区二区三区| yourporn久久国产精品| 日韩欧美国产电影| 国产精品成人免费| 免费视频最近日韩| 日本久久电影网| 久久蜜臀精品av| 婷婷综合五月天| 欧美丝袜自拍制服另类| 国产精品妹子av| 国产老肥熟一区二区三区| 8x8x8国产精品| 一区二区三区日韩在线观看| 国产成人精品在线看| 日韩欧美一区二区在线视频| 亚洲一区在线视频观看| 99精品久久免费看蜜臀剧情介绍| 久久嫩草精品久久久久| 蜜桃av一区二区三区| 欧美区视频在线观看| 洋洋av久久久久久久一区| 成人午夜免费视频| 国产三级欧美三级日产三级99| 日本色综合中文字幕| 51精品秘密在线观看| 午夜视频在线观看一区二区三区| 99久久伊人网影院| 国产精品第13页| 成人激情av网| 国产精品久久免费看| 成人丝袜高跟foot| 中文字幕精品一区| 成人福利视频网站| 国产精品高清亚洲| 99久久精品免费看| 自拍偷自拍亚洲精品播放| 成人av在线观| 国产精品国产馆在线真实露脸| 成人深夜在线观看| 中文字幕制服丝袜成人av | 成人美女在线视频| 久久精品欧美日韩| 成人午夜在线播放| 亚洲欧洲综合另类在线| 色综合 综合色| 亚洲国产精品久久久久秋霞影院| 在线欧美一区二区| 日一区二区三区| 欧美一级片在线| 国产成人精品亚洲午夜麻豆| 中文av字幕一区| 色婷婷国产精品| 青青草国产成人99久久| 欧美v日韩v国产v| 国产成人免费在线观看不卡| 自拍偷拍欧美精品| 欧美嫩在线观看| 国产精品91一区二区| 中文字幕一区三区| 欧美日韩成人综合| 国产在线精品一区二区不卡了| 国产欧美一区二区精品婷婷| 色婷婷精品大在线视频| 午夜欧美视频在线观看| 欧美va亚洲va香蕉在线| 国产99精品在线观看| 亚洲激情中文1区| 日韩一区二区三区电影在线观看| 国产精品伊人色| 亚洲一区二区三区爽爽爽爽爽| 欧美大片顶级少妇| jvid福利写真一区二区三区| 亚洲午夜精品网| 国产免费成人在线视频| 欧美视频自拍偷拍| 福利一区在线观看| 香蕉成人啪国产精品视频综合网| 亚洲精品一区二区三区福利| 96av麻豆蜜桃一区二区| 麻豆国产91在线播放| 亚洲色图.com| 2023国产精华国产精品| 欧美无人高清视频在线观看| 国产一区美女在线| 亚洲va在线va天堂| 中文字幕中文乱码欧美一区二区| 日韩一级成人av| 欧美日韩一区精品| av电影一区二区| 国产精品一级在线| 奇米精品一区二区三区四区| 亚洲乱码中文字幕综合| 中文字幕精品三区| 精品日韩欧美一区二区| 精品视频在线视频| 色哟哟一区二区三区| 成人小视频在线观看| 韩国精品主播一区二区在线观看 | 五月天网站亚洲| 中文字幕一区二区三区在线观看| 日韩欧美一区二区三区在线| 色老汉一区二区三区| 天天操天天干天天综合网| 国产精品久久777777| 久久久国产午夜精品| 在线免费观看成人短视频| 不卡的看片网站| 久久精品72免费观看| 丝袜诱惑亚洲看片| 一区二区三区四区视频精品免费 | 成人欧美一区二区三区在线播放| 99免费精品视频| 成人性色生活片免费看爆迷你毛片| 蜜臀av性久久久久蜜臀aⅴ| 婷婷国产在线综合| 亚洲成人高清在线| 亚洲成人福利片| 午夜免费欧美电影| 午夜视频在线观看一区二区| 亚洲成人av免费| 午夜精品福利一区二区三区av | www.久久精品| 不卡的av电影在线观看| 99久久久无码国产精品| 色婷婷久久99综合精品jk白丝| 一本色道久久综合精品竹菊| 色综合久久综合网欧美综合网 | 成人欧美一区二区三区黑人麻豆| 国产精品久久久久久久蜜臀| 精品国产免费视频| 久久这里只有精品首页| 久久精品综合网| 国产偷v国产偷v亚洲高清| 久久久高清一区二区三区| 欧美国产欧美综合| 亚洲婷婷国产精品电影人久久| 日韩久久一区二区| 亚洲国产精品久久久久婷婷884| 午夜精品久久久久久久99樱桃| 日韩影院在线观看| 91精品一区二区三区在线观看| 精品粉嫩超白一线天av| 国产午夜三级一区二区三| 国产精品久久久一本精品| 亚洲柠檬福利资源导航| 日韩在线一区二区| 国产精品一二三在| 91小视频在线免费看| 在线观看免费视频综合| 日韩一区二区三| 亚洲精品一区二区三区在线观看| 国产精品嫩草99a| 天堂蜜桃91精品| 狠狠色丁香婷婷综合| 国产激情一区二区三区四区| 99热精品一区二区| 欧美一级国产精品| 中文字幕在线不卡| 视频一区视频二区中文字幕| 国产成人自拍网| 韩国中文字幕2020精品| 色八戒一区二区三区| 欧美电影免费观看高清完整版| 综合久久久久综合| 午夜a成v人精品| 成人一二三区视频| 91精品在线观看入口| 亚洲欧洲av另类| 精品亚洲porn| 777色狠狠一区二区三区| 欧美极品少妇xxxxⅹ高跟鞋|