Golang语言中的Prometheus的日志模块使用案例代码编写
更新时间:2024年08月10日 09:31:06 作者:尹正杰
这篇文章主要介绍了Golang语言中的Prometheus的日志模块使用案例,本文给大家分享源代码编写方法,感兴趣的朋友跟随小编一起看看吧
一.源代码编写
package main import ( "fmt" "os" "path/filepath" "time" "github.com/alecthomas/kingpin/v2" "github.com/go-kit/log" "github.com/go-kit/log/level" "github.com/prometheus/common/promlog" promlogflag "github.com/prometheus/common/promlog/flag" "github.com/prometheus/common/version" ) var ( videos = "https://space.bilibili.com/600805398/channel/series" docs = "https://www.cnblogs.com/yinzhengjie" // 命令行解析 app = kingpin.New(filepath.Base(os.Args[0]), fmt.Sprintf("yinzhengjie-devops'server Program, docs: %s, videos: %s", docs, videos)) // 指定配置文件 configFile = app.Flag("config.file", "configuration file path").Short('c').Default("yinzhengjie-devops-server.yaml").String() ) // Logger用于设置prometheus的Logger, func Logger(config *promlog.Config) log.Logger { var ( l log.Logger le level.Option ) // 设置日志的输出格式 if config.Format.String() == "logfmt" { l = log.NewLogfmtLogger(log.NewSyncWriter(os.Stderr)) } else { l = log.NewJSONLogger(log.NewSyncWriter(os.Stderr)) } // 设置日志级别 switch config.Level.String() { case "debug": le = level.AllowDebug() case "info": le = level.AllowInfo() case "warn": le = level.AllowWarn() case "error": le = level.AllowError() } l = level.NewFilter(l, le) // CST可视为美国、澳大利亚、古巴或中国的标准时间,CST可以为如下4个不同的时区的缩写: // 美国中部时间:Central Standard Time (USA) UT-6:00 // 澳大利亚中部时间:Central Standard Time (Australia) UT+9:30 // 中国标准时间:China Standard Time UT+8:00 // 古巴标准时间:Cuba Standard Time UT-4:00 // // 重新设置一下时区,否则是UTC时间,建议设置CST时区,我们以北京的东八区时间为准。 l = log.With(l, "cts", log.TimestampFormat( func() time.Time { return time.Now().Local() }, "2006-01-02T15:04:05.000Z08:00", ), "caller", log.DefaultCaller) return l } func main() { // 版本信息 // app.Version("v1.0") app.Version(version.Print("yinzhengjie-devops-server")) // 帮助信息 app.HelpFlag.Short('h') promlogConfig := promlog.Config{} promlogflag.AddFlags(app, &promlogConfig) // 强制解析 kingpin.MustParse(app.Parse(os.Args[1:])) fmt.Printf("configFile: %s\n", *configFile) // 设置prometheus的logger var logger log.Logger = Logger(&promlogConfig) // 输出日志事件时需要指定日志级别,此处我指定的日志级别为"info" level.Info(logger).Log( // 注意,写入的数据成对出现,比如下面的案例我就写了5对测试数据。 "Name", "尹正杰", "Hobby", "Golang K8S Docker", "blog", "https://www.cnblogs.com/yinzhengjie", "cfg", *configFile, "age", 18, ) }
二.编译
go build -o server -ldflags "-X 'github.com/prometheus/common/version.BuildUser=y1053419035@qq.com' -X 'github.com/prometheus/common/version.BuildDate=`date`' -X 'github.com/prometheus/common/version.Version=v0.2'" src/models/server/server.go
三.测试
1.查看服务的版本信息 ./server --version 2.指定程序的配置文件 ./server -c /etc/nginx/conf.d/games.conf 3.查看程序的帮助信息 ./server -h 4.不指定任何参数 ./server 5.指定日志输出格式 ./server --log.format=json 6.同时指定多个参数 ./server --log.format=json -c /etc/nginx/nginx.conf
当你的才华还撑不起你的野心的时候,你就应该静下心来学习。当你的能力还驾驭不了你的目标的时候,你就应该沉下心来历练。问问自己,想要怎样的人生。 欢迎交流学习技术交流,个人微信: "JasonYin2020"(添加时请备注来源及意图备注) 作者: 尹正杰, 博客: https://www.cnblogs.com/yinzhengjie/p/18351921
到此这篇关于Golang语言中的Prometheus的日志模块使用案例代码编写的文章就介绍到这了,更多相关Golang Prometheus日志模块使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
关于Golang中for-loop与goroutine的问题详解
这篇文章主要给大家介绍了关于Golang中for-loop与goroutine问题的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用golang具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。2017-09-09
最新评论