草庐IT

日志告警

全部标签

go - 如何从其他文件访问我的日志实例

我最近开始学习Go,当我决定将我的代码放在多个文件(main.go)中时,出现了一个问题。我经常需要的常用内容(如日志、缓存、配置、指标等)在其他文件中都不可用,即使它们属于同一个“packagemain”。我想根据配置(viper包)中的数据配置一次我的日志实例(logrus包)。而这仅仅是个开始,我很快就会有一个DB实例(?)、Cache实例等。解决我的问题的最好方法是什么,围棋的最佳实践是什么?如何遵循DRY原则?如果我将我的初始日志设置放入“mylog”包中,然后将其导入到每个包的每个文件中,那么会有多少个mylog实例?每个文件/包/??有效率吗?Log和Config也是相互

go - 在 Hyperledger fabric 中,如何打印出链代码函数的消息和日志?

我想通过Golang测试我的链代码,所以我使用了Hyperledgerfabricchaincodedev测试。链码的所有功能(调用、查询等)都有效,但控制台上没有链码的日志和消息。在每种情况下,日志记录都设置为“调试”。我想在控制台打印出调用、查询的结果消息,但只打印出消息:“myc”;“我的C”;“我的C”;...2019-03-1518:07:04.550UTC[shim]setupChaincodeLogging->INFO001Chaincodeloglevelnotprovided;defaultingto:INFO2019-03-1518:07:04.550UTC[shi

go - 无法通过 kubectl logs 命令检索 go 客户端中的 POD 日志

在我们的Kubernetes中,有一个不断重启的POD。如果我使用kubectllogs-pPOD_NAME-nNAMESPACE命令,我会得到详细的日志。然而,当我们使用kubernetes的go客户端并尝试检索日志时,我们什么也得不到。我们正在使用PodExpansion接口(interface)的GetLogs(namestring,opts*v1.PodLogOptions)方法。我还尝试在PodLogOptions中使用各种选项,例如。sinceSeconds=BeginningOfTheYear但运气不好。非常感谢任何帮助。 最佳答案

python - 带有 Web 后端的日志存储

我们需要存储来自某些服务的日志,每个日志都有其级别、命名空间(可能是虚线命名空间)、标签(作为列表)、时间戳(日志创建时间)及其内容(作为文本)。我们还需要一个能够显示/搜索/过滤日志及其级别、命名空间和标签的网络后端。有开源系统吗?我更喜欢Go或Python语言。如果不是,对我们来说最好的解决方案是什么?我不知道这个问题对于stackoverflow是否合法。我只是问一个开源解决方案。感谢您阅读本文, 最佳答案 在我看来,我将分析一些我知道的开源日志系统:logstash:您需要kibana或任何相同的Web界面。logstash

logging - 使用 Golang 包日志将行附加到文件,而不是获取新行。

当我使用log写入文本文件时,我正在使用golang包“log”,它不会在末尾附加新的文本行。它把所有东西都放在一起。Thisishowitlooks.HowIwouldlikeittolook.当前代码。f,err:=os.OpenFile("D:\\temp2\\testlogfile.txt",os.O_RDWR|os.O_CREATE|os.O_APPEND,0666)iferr!=nil{Error.Fatalf("erroropeningfile:%v",err)}deferf.Close()multi:=io.MultiWriter(os.Stdout,f)log.Set

logging - 在 Golang 中将每个日志保存在单独的行中

我试图为我的代码添加日志,但我无法让每个日志都在单独的行上这是我的代码packagemainimport("log""os")funcupdate(){log.Println(1,"update")log.Println(1,"update")log.Println(1,"update")log.Println(1,"update")}funcinstall(){log.Println(1,"install")log.Println(1,"install")log.Println(1,"install")log.Println(1,"install")}funcmain(){//mak

testing - 如何在 Golang 中测试日志记录(log.Println)?

如何在Golang中测试下面的代码?packagemainimport"log"funcmain(){log.Println("helloworld")} 最佳答案 您的程序写入log包标准记录器,后者写入标准错误。编译并运行你的程序,看看标准错误中出现了什么。 关于testing-如何在Golang中测试日志记录(log.Println)?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/quest

go - Zap 记录器打印到控制台和日志文件

我已将Zap与我的go应用程序集成,我们将日志打印在两个日志文件中,我还使用Lumberjack进行日志轮换。但我也试图在控制台中显示日志,但这种情况下运气不好。以下是我在logger.go中的代码var(Logger*zap.LoggerN2n*zap.Logger)typeWriteSyncerstruct{io.Writer}func(wsWriteSyncer)Sync()error{returnnil}funcInitLogging(modestring){varcfgzap.ConfigvarlogName="abc.log"varslogName="n2n.log"ifm

go - 有什么方法可以使用 golang std 库来格式化日志(如下所述)?

2018年2月1日下午3:04:05(UTC)|这是日志消息2018-02-01T15:04:05Z|这是日志消息我在gosrc中找到了下一个格式:https://github.com/golang/go/blob/master/src/log/log.go#L37但似乎我无法仅使用那些来做到这一点.. 最佳答案 这里有两个选项:使用log.SetOutput设置自定义编写器。或者使用fmt包而不是只打印到stdout或其他地方-stdlib日志包做的不多而且很容易创建你自己的日志包,它以自定义时间格式输出到stdout(或日志文件

go - 正在将标准库日志重定向到 logrus 线程安全

我正在使用logrus我的Go项目中用于结构化日志记录的库。我的logrus配置如下://GlobalvariableforloggingvargLog=&Logger{moduleName:ModuleName,logrus:logrus.New()}typeLoggerstruct{moduleNamestringlogrus*logrus.Logger}funcSetupGlobalLogger(logPrefixstring,logModestring)error{iflogMode=="file"{logFilePath:=fmt.Sprintf("var/%s.log",v