草庐IT

日志告警

全部标签

go - 如何将日志写入多个文件?

在Golang中,你们如何设法根据包名称将日志写入多个文件。例如,在我当前的应用程序中,我试图从名为Netapp、IBM等但在同一应用程序下的不同软件包中收集多个硬件统计信息。所以,我想将这些包中的日志写入单独的文件夹中,例如/var/log/myapp/netapp.log和/var/log/myapp/ibm.log?任何指示或线索都会很有帮助吗?谢谢詹姆斯 最佳答案 您可以采用的一种方法是实现观察者模式。当您需要对同一个输入/事件进行多项操作时,这是一种很好的方法。在您的情况下,将相同的输入记录到不同的日志中。您可以找到更多信

go - Uber Zap 记录器不在日志语句中打印调用者信息

我正在尝试使用配置的自定义编码器将相同的消息同时发送到控制台和日志文件。在此过程中,我想显示来电者信息,但即使我按照文档中的建议使用了caller键,也不会显示相同的信息。下面是相同的示例代码packagemainimport("os""time""go.uber.org/zap""go.uber.org/zap/zapcore""gopkg.in/natefinch/lumberjack.v2")varlogLevelSeverity=map[zapcore.Level]string{zapcore.DebugLevel:"DEBUG",zapcore.InfoLevel:"INFO

web - 通过 websocket 将 kubernetes 日志暴露给浏览器

我正在尝试在kubernetes中使用sidecar模式来创建日志sidecar以公开特定的容器日志。我正在使用kubernetes客户端从kubernetesapi获取日志并通过websocket发送出去。代码如下:funcserveWs(whttp.ResponseWriter,r*http.Request){w.Header().Set("Access-Control-Allow-Origin","*")conn,err:=upgrader.Upgrade(w,r,nil)iferr!=nil{if_,ok:=err.(websocket.HandshakeError);!ok{

go - stackdriver 是否可以识别来自 k8s 的系统日志输入?

无法让堆栈驱动程序识别系统日志级别。尽管指定了DEBUG,但一切都显示为错误logwriter,e:=syslog.New(syslog.LOG_DEBUG,"myprog")ife==nil{log.SetOutput(logwriter)}log.Print("logme")我知道格式requirements如果我输出正确的格式作为json有效负载,stackdriver会神奇地拾取它并且它对我有用。但为什么即使我对json有效负载进行syslog,stackdriver也无法识别syslog输入? 最佳答案 Syslog是一种

go - 设置 Martini 日志路径

如何将martini日志路径设置为某个随机文件。它现在显示在控制台中。m:=martini.Classic()感谢帮助 最佳答案 将新记录器附加到Martini:f,err:=os.OpenFile("logfile",os.O_RDWR|os.O_CREATE|os.O_APPEND,0666)iferr!=nil{t.Fatalf("erroropeningfile:%v",err)}deferf.Close()m.Map(log.New(f,"[martini]",log.LstdFlags))

golang 系统日志故障 : Unix syslog delivery error

我在运行Mavericks10.9.2的OSX上。我正在尝试让我的Revel应用程序记录到系统日志。我的代码在此行失败:sysLog,err:=syslog.New(syslog.LOG_NOTICE|syslog.LOG_LOCAL0,"myApp")出现此错误:Unixsyslogdeliveryerror系统日志肯定在我的机器上运行。可能是什么问题? 最佳答案 验证系统日志是否正在运行或启用它。$ps-aux|grepsyslogroot117030.00.4144241992-IsJ9:17AM0:00.01/usr/sbi

azure - 如何从 Azure Web App 上的 go app 跟踪日志

我正在尝试找到如何让我的go应用程序中的fmt.Printf或log.Printf像我们能够为.NET或Node应用程序添加到应用程序日志。基于此article(archivelink)通过从门户启用应用程序日志记录,应该记录所有标准输出。但由于某些原因,我的日志输出在使用azureCLI或下载日志时都没有打印出来。diagnostics.zip的LogFiles目录中没有Application目录。azuresitelogtailsitename或azuresitelogdownloadsitename在Node中,我使用IISNode.yml文件告诉我将console.log记录到

logging - Golang 日志记录策略

与Python中的logging标准库不同,Go中的标准log包不支持级别。许多包求助于第三方日志包,例如glog或logrus。当导入可能使用或不使用第三方日志包的第三方包时,Go的最佳日志记录策略是什么。 最佳答案 所以,我想你是在问,如果我正在使用的包使用普通的旧https://golang.org/pkg/log/怎么办?我的主包使用了一些特殊的东西,比如log.Info、log.Warn、log.Error和log.Debug?如果包向您公开了log.Logger对象,您可以使用SetFlags、SetOutput、Set

json - 使用 Go 将 JSON 日志重复存储为文件并确保文件名唯一

我是Go的新手,我正在有效地从API反复接收一个小的(~1KB)JSON文件,它实际上是一个日志,我想保留这些文件中的每一个。我正在考虑将每个JSONblock作为唯一文件存储在特定目录中(代替使用数据库,这似乎没有必要)。首先,这个想法好吗?每天可能有几百个。更重要的是,我如何确保文件名的唯一性?显然我不能将每个都保存为log.json并收工,因为会有冲突。如何确保唯一性? 最佳答案 这是否是个好主意是主观的,但您可以使用ioutil.TempFile以确保您拥有唯一的文件名。TempFile将向您选择的文件前缀附加保证唯一的后缀

logging - Golang 日志函数返回参数

我想记录一个函数的返回值。我能想到的“最聪明”的事情是将我的实际函数体包装在一个闭包中。funcfoo(aint,bint)(int,error){c,err:=func(aint,bint)(int,error){//...returnc,err}(a,b)fmt.Printf("%v%v%v%v",a,b,c,err)returnc,err}有没有一种方法可以用更少的样板文件来实现这一点? 最佳答案 也许我误解了你的问题,但是:packagemainimport("log")funcfoo(a,bint)(cint,errerr