(17)go-micro微服务Prometheus监控

本文涉及的产品
云原生网关 MSE Higress,422元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: (17)go-micro微服务Prometheus监控

Prometheus监控介绍

1.微服务监控系统promethues介绍

  • 是一套开源的监控&报警&时间序列数据库的组合
  • 基本原理是通过HTTP协议周期性抓取被监控组件的状态
  • 适合Docker、 Kubernetes环境的监控系统

7.png

2.微服务监控系统promethues工作流程

Prometheus server定期从配置好的jobs/exporters/Pushgateway中拉数据


Prometheus server记录数据并且根据报警规则推送alert数据


Alertmanager 根据配置文件,对接收到的警报进行处理,发出告警。


在图形界面中,可视化采集数据



二 Prometheus监控重要组件和重要概念

1.微服务监控系统promethues重要组件

Prometheus Server:用于收集和存储时间序列数据。


Client Library:客户端库成相应的metrics并暴露给Prometheus server


Push Gateway:主要用于短期的jobs


Exporters: 用于暴露已有的第三方服务的metrics给Prometheus


Alertmanager: 从Prometheus server端接收到alerts后,会进行


2.微服务监控系统promethues重要概念

Prometheus 中存储的数据为时间序列


格式上由metric的名字和一系列的标签(键值对)唯一标识组成


不同的标签则代表不同的时间序列


Counter 类型: - -种累加的指标,如:请求的个数,出现的错误数等


Gauge 类型:可以任意加减,如:温度,运行的goroutines的个数


Histogram 类型:可以对观察结果采样,分组及统计,如:柱状图


Summary 类型:提供观测值的count和sum功能,如:请求持续时间


instance : -个单独监控的目标,一般对应于一 个进程。


jobs:一组同种类型的instances (主要用于保证可扩展性和可靠性)


三 微服务监控系统grafana看板

  • 拥有 丰富dashboard和图表编辑的指标分析平台
  • 拥有自己的权限管理和用户管理系统
  • Grafana 更适合用于数据可视化展示


四 Prometheus监控+Grafana看板安装

1.安装Prometheus监控

  • 拉取镜像:
docker pull bitnami/prometheus
  • 运行:
docker run -d -p 9090:9090 bitnami/prometheus
  • 查看是否运行:
docker ps
  • 图形化界面:


2.安装Grafana看板

  • 拉取镜像:
docker pull grafana/grafana
  • 运行:
docker run -d -p 3000:3000 grafana/grafana

  • 查看是否运行:
docker ps
  • 图形化界面:


五 Prometheus监控使用

  • 在micro目录下新建prometheus.go文件
go get github.com/prometheus/client_golang/prometheus/promhttp
  • 编写以下代码:
package micro
import (
   "github.com/prometheus/client_golang/prometheus/promhttp"
   "log"
   "net/http"
   "strconv"
)
func PrometheusBoot(host string,port int){
   http.Handle("/metrics",promhttp.Handler())
   //启动web服务
   go func() {
      err := http.ListenAndServe(host+":"+strconv.Itoa(port),nil)
      if err!= nil{
         log.Fatal(("监控启动失败"))
      }
      log.Fatal("监控启动,端口为: "+strconv.Itoa(port))
   }()
}

六 Prometheus监控注册服务

  • 导包:
go get github.com/micro/go-plugins/wrapper/monitoring/prometheus/v2


  • 在main.go文件中写入以下代码
// 7.暴露监控地址
micro2.PrometheusBoot(micro2.ConsulInfo.Prometheus.Host, int(micro2.ConsulInfo.Prometheus.Port))
  • 注:传的参数是使用consul导入的,可以换成自定义的
  • 注册服务
//添加监控
micro.WrapHandler(prometheus.NewHandlerWrapper()),

8.png

七 Prometheus监控图形化界面

  • 运行项目

Prometheus原生看板


9.png



Grafana看板

  • 首次登录,账号:admin;密码:admin
  • 10.png

八 最后

  • 至此,go-micro微服务Prometheus监控工作就正式完成。
  • 接下来就开始微服务ELK介绍的代码编写了,希望大家关注博主和关注专栏,第一时间获取最新内容,每篇博客都干货满满。
相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
相关文章
|
1月前
|
JavaScript Java Go
探索Go语言在微服务架构中的优势
在微服务架构的浪潮中,Go语言以其简洁、高效和并发处理能力脱颖而出。本文将深入探讨Go语言在构建微服务时的性能优势,包括其在内存管理、网络编程、并发模型以及工具链支持方面的特点。通过对比其他流行语言,我们将揭示Go语言如何成为微服务架构中的一股清流。
120 53
|
3月前
|
Go API Docker
热门go与微服务15
热门go与微服务15
35 2
|
4月前
|
Prometheus 监控 Kubernetes
Prometheus 在微服务架构中的应用
【8月更文第29天】随着微服务架构的普及,监控和跟踪各个服务的状态变得尤为重要。Prometheus 是一个开源的监控系统和时间序列数据库,非常适合用于微服务架构中的监控。本文将详细介绍 Prometheus 如何支持微服务架构下的监控需求,包括服务发现、服务间的监控指标收集以及如何配置 Prometheus 来适应这些需求。
157 0
|
1月前
|
监控 Go API
Go语言在微服务架构中的应用实践
在微服务架构的浪潮中,Go语言以其简洁、高效和并发处理能力脱颖而出,成为构建微服务的理想选择。本文将探讨Go语言在微服务架构中的应用实践,包括Go语言的特性如何适应微服务架构的需求,以及在实际开发中如何利用Go语言的特性来提高服务的性能和可维护性。我们将通过一个具体的案例分析,展示Go语言在微服务开发中的优势,并讨论在实际应用中可能遇到的挑战和解决方案。
|
1月前
|
Go 数据处理 API
Go语言在微服务架构中的应用与优势
本文摘要采用问答形式,以期提供更直接的信息获取方式。 Q1: 为什么选择Go语言进行微服务开发? A1: Go语言的并发模型、简洁的语法和高效的编译速度使其成为微服务架构的理想选择。 Q2: Go语言在微服务架构中有哪些优势? A2: 主要优势包括高性能、高并发处理能力、简洁的代码和强大的标准库。 Q3: 文章将如何展示Go语言在微服务中的应用? A3: 通过对比其他语言和展示Go语言在实际项目中的应用案例,来说明其在微服务架构中的优势。
|
2月前
|
Cloud Native Go API
Go语言在微服务架构中的创新应用与实践
本文深入探讨了Go语言在构建高效、可扩展的微服务架构中的应用。Go语言以其轻量级协程(goroutine)和强大的并发处理能力,成为微服务开发的首选语言之一。通过实际案例分析,本文展示了如何利用Go语言的特性优化微服务的设计与实现,提高系统的响应速度和稳定性。文章还讨论了Go语言在微服务生态中的角色,以及面临的挑战和未来发展趋势。
|
2月前
|
运维 Go 开发者
Go语言在微服务架构中的应用与优势
本文深入探讨了Go语言在构建微服务架构中的独特优势和实际应用。通过分析Go语言的核心特性,如简洁的语法、高效的并发处理能力以及强大的标准库支持,我们揭示了为何Go成为开发高性能微服务的首选语言。文章还详细介绍了Go语言在微服务架构中的几个关键应用场景,包括服务间通信、容器化部署和自动化运维等,旨在为读者提供实用的技术指导和启发。
|
2月前
|
负载均衡 Go API
探索Go语言在微服务架构中的应用与优势
在这篇技术性文章中,我们将深入探讨Go语言(又称为Golang)在构建微服务架构时的独特优势。文章将通过对比分析Go语言与其他主流编程语言,展示Go在并发处理、性能优化、以及开发效率上的优势。同时,我们将通过一个实际的微服务案例,详细说明如何利用Go语言构建高效、可扩展的微服务系统。
|
2月前
|
安全 Go 云计算
探索Go语言在微服务架构中的应用与优势
在本文中,我们将深入探讨Go语言(又称为Golang)在构建微服务架构中的独特优势。文章将分析Go语言的并发模型、简洁的语法以及高效的编译速度,以及这些特性如何使其成为微服务架构的理想选择。我们将通过一个简单的微服务示例,展示Go语言在实际开发中的表现,并讨论其在性能和可维护性方面的优势。
|
2月前
|
消息中间件 监控 Go
Go语言在微服务架构中的优势与实践
【10月更文挑战第10天】Go语言在微服务架构中的优势与实践
下一篇
DataWorks