草庐IT

Prometheus告警规则

全部标签

go - 如何在 golang 网络服务器中使用 prometheus 监控请求成本时间

我有几个url可以访问,我想用prometheus监控每个请求的成本时间。但我不知道使用哪种指标来收集数据。有什么帮助吗?这是演示代码:packagemainimport("github.com/prometheus/client_golang/prometheus""io/ioutil""net/http""fmt""time")var(resTime=prometheus.NewSummaryVec(prometheus.SummaryOpts{Name:"response_time",Help:"costtimeperrequest",},[]string{"costTime"}

正则表达式挑战将不同的规则分成两组

我有以下数据:msg=hellomsg=hellohelloage:s35{getAge}forname=peterid="123"我想使用正则表达式将它们分类为以下第1组(冒号左侧)和第2组(冒号右侧)结构:msg:hellomsg:hello/helloage:thirtyfive{getAge}forname:peter'id:"123"我想出了下面的正则表达式([^,=\s]*)=([^,\s]*)|([^=]*):([^=]*for)除了我有一个不幸的约束之外,这完成了工作。我只能允许两个正则表达式组。如您所见,“年龄”属性和相应的键对应地位于第3组和第4组中。如何在正则表达

go - Go 中 Prometheus 的多个端点

我目前正在开发一个由Prometheus监控的Go(golang)编写的程序。现在程序应该提供两个端点/metrics和/service。当Prometheus在/metrics上抓取时,它应该公开自己的指标(例如发出的请求、请求延迟等),当在/service上抓取时,它应该查询一个API,从那里获取指标并将它们公开给Prometheus。对于第一部分,我创建了例如一个计数器通过requestCount:=kitprometheus.NewCounterFrom(stdprometheus.CounterOpts{Namespace:"SERVICE",Subsystem:"servi

go - Prometheus 指标未使用 Prometheus Go 客户端显示

我正在使用prometheusgolang客户端。代码片段如下。同样的构建工作正常。问题是只显示go指标。xyz_*指标缺失。我将initMetrics()作为main()函数中的第一件事。//Declaringprometheusmetriccountersvar(metric_prefix="xyz_"xyzAPICallsCounter=prometheus.NewCounterVec(prometheus.CounterOpts{Name:metric_prefix+"api_calls_total",Help:"Numberofcallstoxyzendpoint",},[]

go - Prometheus 使用计数器对非静态数据进行计数

我正在尝试计算唯一URI的数量并记录它们的数量。这些URI会随着时间的推移而变化,同一类型的URI可能有多个。例如,可以有多个“/foo”和“/bar”,并且可以进来一个新的URI——比方说“pooh”——我必须将它们添加到计数器并继续计数。在这种情况下,我不能使用常量标签。例如,如果我要按方法和/或状态代码计算http请求的数量,我可以这样做:httpRequestInfo:=prometheus.NewCounterVec(prometheus.CounterOpts{Name:"http_requests_sum",ConstLabels:prometheus.Labels{"c

go - Prometheus type Collector - 如何用我自己的数据提供 map

免责声明:我是Golang的新手,之前没有用任何其他语言做过太多编程。不过,我仍然希望有人能为我指明正确的方向。目标是:根据PrometheusGolang模块(https://godoc.org/github.com/prometheus/client_golang/prometheus#Collector)下的“示例”部分以及提到“//仅示例假数据”的部分。当然是使用我自己的真实数据。我的数据以JSON格式来自RabbitMQ端点。我解析JSON,并且可以使用正确的键创建自己的映射:我需要的值作为funcmain()范围内的goroutine的一部分。假设我的map如下所示:[“设

mysql - 使用错误的排序规则连接到 mysql 服务器?

我有一个Golang程序,它可以连接到具有不同字符集或排序规则的数据库。例如,在编写GolangMYSQL驱动程序时默认为utf8mb4_general_cihttps://github.com/go-sql-driver/mysql#collation但是,如果我连接到这样配置的数据库:CREATEDATABASEexamplecharactersetutf8mb4collateutf8mb4_unicode_ci;我可以预料“坏事会发生”吗?索引不起作用? 最佳答案 在大多数情况下,没有问题。例如,当使用WHEREcolumn=

pointers - golang 异常规则 "interface pointer can' t 实现接口(interface)”

在golang.org的官方常见问题解答中,underpointers有这句话:“洞察力是,尽管指向具体类型的指针可以满足接口(interface),但除了一个异常(exception),指向接口(interface)的指针永远不能满足接口(interface)”出于好奇,上述规则的异常(exception)是什么?即接口(interface)指针何时可以实现接口(interface)? 最佳答案 就在它下面说:Theoneexceptionisthatanyvalue,evenapointertoaninterface,canbe

google-app-engine - 通过 yaml 规则限制登录用户访问 google app engine app 中的静态文件失败

我尝试使用记录的方式来限制对通过登录标记为静态的url的访问:app.yaml文件中的必需规则。我的意图是通过xmlhttprequests访问由go编程语言处理的脚本url,但是在她可以加载文件dist/index.html之前对用户进行身份验证的第一步失败了。令我惊讶的是,用户没有收到登录提示,而是收到了dist/index.html文件和它从静态文件夹中请求的所有其他文件,就好像没有限制规则一样。这是我的app.yaml文件:application:helloworldversion:1runtime:goapi_version:go1handlers:-url:/static_

go - Prometheus - 将指标列表发送到 Gauge

我有一个要发送到prometheus的json格式的指标列表。我如何使用client_golang中的Guage指标类型将这些指标一次全部发送到prometheus?现在我有下面的代码var(dockerVer=prometheus.NewGauge(prometheus.GaugeOpts{Name:"docker_version_latency",Help:"Latencyofdockerversioncommand.",}))funcinit(){//Metricshavetoberegisteredtobeexposed:prometheus.MustRegister(dock