Prometheus + Grafana + Alertmanager 本地安装调试

news2024/12/22 10:29:11

一、简介

Prometheus 是一款强大的监控软件,一般会与Grafana和Alertmanager一起配合使用,而且多用于k8s集群。简介的话网上很多,官网 更是详细,这里就不班门弄斧了。k8s集群环境下的安装网上很多,但是k8s集群搭建时间成本较高,所以这里记录下Centos7环境下的安装使用,以供后来者参考。下面直入正题。

二、环境

  • VMware
  • CentOS7-64
  • MySQL
  • 其他资源安装包(下面安装步骤中的资源如果无法从官网下载,都可以从本人网盘中获取):
    链接:https://pan.baidu.com/s/1MARRrONm9c3Ib0Llc0uyeQ
    提取码:rzd3

三、Prometheus安装

  1. go语言环境
    ①Linux环境安装包:go1.8.3.linux-amd64.tar.gz (86MB)
    ②下载后上传至服务器,执行解压命令

    [root@localhost soft]# tar -xzf go1.8.3.linux-amd64.tar.gz -C /usr/local/
    

    ③配置环境变量

    [root@localhost soft]# vim /etc/profile
    

    文件尾部添加:

    export PATH=$PATH:/usr/local/go/bin
    

    保存后使配置文件生效:

    [root@localhost soft]# source /etc/profile
    

    ④验证是否安装成功

    [root@localhost soft]# go version
    

    执行结果如下:
    go version执行结果

  2. Prometheus下载安装
    ①去官网下载安装包:prometheus-2.41.0.linux-amd64.tar.gz
    ②上传并解压到 /usr/local

    [root@localhost soft]# tar -vxf prometheus-2.41.0.linux-amd64.tar.gz -C /usr/local/
    

    ③修改配置文件

    [root@localhost soft]# vim /usr/local/prometheus-2.41.0.linux-amd64/prometheus.yml
    

    在配置文件最底部配置监控内容(如果不配置,默认会有一个监控,监控的自己),示例:

      - job_name: 'centOS-mysql'
        static_configs:
         - targets: ['192.168.121.128:9104']
    

    注意:targets后面的地址是exporters 的IP和端口号,exporter在后面会有说明
    ④启动:

    [root@localhost soft]# cd /usr/local/prometheus-2.41.0.linux-amd64/
    [root@localhost prometheus-2.41.0.linux-amd64]# ./prometheus
    

    启动日志如下:
    Prometheus启动日志
    ⑤Prometheus启动成功后有默认访问端口9090,可以访问页面,访问如下:https://img-blog.csdnimg.cn/5b83c2c4173e461690c58ca85b3b1300.png

四、 Exporter 安装

  1. 简介:Exporter进行实际的数据采集,Prometheus实际连接的是Exporter服务,如上面centOS-mysql监控之所以状态为“DOWN”,就是因为没有装Exporter。
  2. Exporters有多种,可以从官网选用合适自己的,官网地址:https://prometheus.io/docs/instrumenting/exporters/
    本次调试监控了服务器本身及MySQL数据库,所以对这两种进行简单说明:
    监控服务器需要下载安装:node_exporter-1.5.0.linux-amd64.tar.gz
    监控MySQL需要下载安装:mysqld_exporter-0.14.0.linux-amd64.tar.gz
  3. 下载成功后,上传至服务器,并进行解压操作:
    [root@localhost soft]# tar -vxf mysqld_exporter-0.14.0.linux-amd64.tar.gz -C /usr/local/
    
  4. 在mysqld-exporter安装路径下,创建.my.cnf文件
    [root@localhost soft]# vim /usr/local/mysqld_exporter-0.14.0.linux-amd64/.my.cnf
    
    配置mysql的账户及密码
    [client]
    user=XXX
    password=XXX
    
    建议:监控账户,单独新建一个,并限制权限,例如
    CREATE USER 'mysql_monitor'@'localhost' IDENTIFIED BY 'Mysql@123' WITH MAX_USER_CONNECTIONS 3;
    GRANT PROCESS, REPLICATION CLIENT, SELECT ON *.* TO 'mysql_monitor'@'localhost';
    FLUSH PRIVILEGES;
    EXIT
    
  5. 进入mysqld_exporter的安装目录,启动服务
    [root@localhost soft]# ./mysqld_exporter --config.my-cnf=./.my.cnf
    
  6. 启动成功后,日志乳腺,默认端口9104
    mysqld_exporter启动日志
  7. 刷新Prometheus,发现监控服务上线(安装Prometheus时配置过了)
    mysql_exporter监控上线

五、Grafana安装使用

  1. 下载安装包并进行安装,官方下载地址:https://grafana.com/grafana/download,本次使用的为:grafana-5.2.3-1.x86_64.rpm
    [root@localhost soft]# wget https://s3-us-west-2.amazonaws.com/grafana-releases/release/grafana-5.2.3-1.x86_64.rpm 
    [root@localhost soft]# sudo yum localinstall grafana-5.2.3-1.x86_64.rpm
    
  2. 将Grafana加入服务列表,进行启动
[root@localhost soft]# sudo /sbin/chkconfig --add grafana-server
[root@localhost soft]# sudo service grafana-server start
  1. 访问:Grafana默认端口3000,默认账户密码:admin/admin,登录后如下:
    Grafana登录后的界面
  2. 添加数据源:
    Grafana-Data Sources
    添加数据源配置如下:
    add Data Source
  3. 展示:
    选中Prometheus 2.0 Stats,监控界面如下:
    Grafana监控界面
    上面的界面不容易理解,所以需要根据需求,在Grafana中导入模板,本文导入了MySQL的展示模板,模板下载地址:https://grafana.com/api/dashboards/8564/revisions/10/download,下载下来是一个json文件:mysql-overview_rev10.json
    如下操作导入模板:
    Grafana导入模板
    导入后,展示界面如下:
    MySQL监控展示

六、Alertmanager 的安装使用

  1. 下载安装包:alertmanager-0.25.0.linux-amd64.tar.gz
    下载地址:https://prometheus.io/download/

  2. 上传至服务器,并进行解压安装

    [root@localhost soft]# tar -vxf alertmanager-0.25.0.linux-amd64.tar.gz -C /usr/local/
    
  3. 修改配置文件

    [root@localhost ~]# vim /usr/local/alertmanager-0.25.0.linux-amd64/alertmanager.yml
    
    global:
      resolve_timeout: 5m
      smtp_smarthost: 'smtp.163.com:465'
      smtp_from: '18XXXXXXXX@163.com'
      smtp_auth_password: 'EBEXXXXXX'
      smtp_require_tls: false
      smtp_auth_username: '18XXXXXXXX@163.com'
      smtp_hello: '163.com'
    
    route:
      group_by: ['alertname']
      group_wait: 10s
      group_interval: 1m
      repeat_interval: 10m
      receiver: 'AJ'
    receivers:
      - name: 'AJ'
        email_configs:
          - to: '79XXXXXXX@163.com'
    inhibit_rules:
      - source_match:
          severity: 'critical'
        target_match:
          severity: 'warning'
        equal: ['alertname', 'dev', 'instance']
    
    
  4. 启动服务

    [root@localhost soft]# cd /usr/local/alertmanager-0.25.0.linux-amd64/
    [root@localhost soft]# ./alertmanager --config.file=alertmanager.yml
    

    启动日志:alertmanager启动日志

  5. 修改prometheus配置文件

    [root@localhost soft]# vim /usr/local/Prometheus/prometheus.yml 
    
    # Alertmanager configuration
    alerting:
      alertmanagers:
        - static_configs:
            - targets:
               - 192.168.121.128:9093
    
    # Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
    rule_files:
       - "/home/soft/rules/mysql_rules.yml"
      # - "first_rules.yml"
      # - "second_rules.yml"
    
    
  6. 配置告警规则,这里只进行简单配置,测试使用,修改规则后需要重启prometheus生效

    [root@localhost rules]# vim /home/soft/rules/mysql_rules.yml 
    
    groups:
    - name: 通用实例监控
      rules:
      - alert: 实例DOWN
        expr: mysql_up == 0
        for: 1m  # 如果1m之内,实例都是up==0状态,才会告警
        labels:
          severity: error
        annotations:
          description: '{{ $labels.instance }} of job {{ $labels.job }} 挂掉超过1分钟.'
          summary: '实例:{{ $labels.instance }}已死,请处理...'
    

    测试时,可以把指标灵活调整,方便触发报警,例如 mysql_up == 1(实例数),触发报警后,邮件内容如下:
    alertmanager预警邮件示例

七、参考文献

  1. https://prometheus.io/docs/introduction/overview/
  2. https://blog.csdn.net/csolo/article/details/82460539?spm=1001.2101.3001.6650.9&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7ERate-9-82460539-blog-124677519.pc_relevant_3mothn_strategy_recovery&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7ERate-9-82460539-blog-124677519.pc_relevant_3mothn_strategy_recovery&utm_relevant_index=15
  3. http://t.zoukankan.com/z-qinfeng-p-12748240.html
  4. https://blog.csdn.net/qq_34556414/article/details/121777449
  5. https://blog.csdn.net/guiyiba/article/details/122634820

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/185997.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【实际开发10】- 远程调用 ( Feign )

目录 1. Feign 调用注意事项 - ★★★ 1. 【原则】: 禁止遍历 - 多次跨服务调用接口 ( 提需求 : idList ) 1. 单一数据查询 , 可直接用 Feign单一查询接口 2. List数据查询 , 需进行 Feign 数据转换 , 禁止遍历 Feign 3. stream() : 从List<对象> , 取出 id 和 name…

关于PS VR2和独占,开发者和分析师都怎么看

近期&#xff0c;索尼正式宣布了PS VR2首发游戏列表&#xff0c;共计37款游戏&#xff0c;其中包括备受关注的IP大作《地平线&#xff1a;山之召唤》等。从这37款首发阵容中可以看到一个现象&#xff0c;大部分游戏是非新作&#xff0c;而是已经在PS VR1或其它VR平台上线&#…

C++基础——C++数组

C基础——C数组C 数组声明数组初始化数组访问数组元素C 中数组详解C 数组 C 支持数组数据结构&#xff0c;它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据&#xff0c;但它往往被认为是一系列相同类型的变量。 数组的声明并不是声明一个个单独的…

【数据结构基础】线性表 - 链表

n个节点离散分配&#xff0c;彼此通过指针相连&#xff0c;每个节点只有一个前驱节点&#xff0c;每个节点只有一个后续节点&#xff0c;首节点没有前驱节点&#xff0c;尾节点没有后续节点。确定一个链表我们只需要头指针&#xff0c;通过头指针就可以把整个链表都能推出来。知…

设计模式-UML图

目录 2&#xff0c;UML图 2.1 类图概述 2.2 类图的作用 2.3 类图表示法 2.3.1 类的表示方式 2.3.2 类与类之间关系的表示方式 2&#xff0c;UML图 统一建模语言&#xff08;Unified Modeling Language&#xff0c;UML&#xff09;是用来设计软件的可视化建模语言。它的特…

Matlab pdetool

云溪岩绵迎彩霞,博主精神压力大呀,没人说说知心话啊,SCU物理要命啦........基本物理方程静电磁场交流电磁场热传导Options->ApplicationGeneric Scalar泛型标量Generic System通用系统Structural Mechanics,Plane Stress结构力学 - 平面应力Structural Mechanics,Plane Stra…

Flashback Oracle文档阅读

和Flashback相关的文档大多位于备份和恢复用户指南 和Oracle 数据库开发指南中。 基本概念 请参看备份和恢复用户指南的1.4 About Oracle Flashback Technology。 Oracle Flashback Technology的定义&#xff1a; A set of Oracle Database features that provide an additi…

Verilog HDL门级建模

⭐本专栏针对FPGA进行入门学习&#xff0c;从数电中常见的逻辑代数讲起&#xff0c;结合Verilog HDL语言学习与仿真&#xff0c;主要对组合逻辑电路与时序逻辑电路进行分析与设计&#xff0c;对状态机FSM进行剖析与建模。 &#x1f525;文章和代码已归档至【Github仓库&#xf…

数字电路设计:Logicly 最新版Crack

Logicly有效地教授逻辑门 数字电路 — 使用 Logicly 现代直观的用户界面支持拖放、复制/粘贴、缩放等功能&#xff0c;可快速轻松地设计电路。 通过暂停模拟并在您逐步推进时观察信号传播来控制调试。 不用担心学生计算机上的多个平台。在 Windows 和 macOS 上安装 创建引人入…

子查询-MySQL

文章目录理解举例基本使用语法分类分类方式1单行子查询多行子查询分类方式2&#xff1a;单行子查询单行比较操作符代码示例HAVING 中的子查询CASE中的子查询子查询中的空值问题非法使用子查询多行子查询多行比较操作符代码示例相关子查询相关子查询执行流程代码示例EXISTS 与 N…

USART学习笔记

目录 1. USART框图 2. 传输帧图 3. 配置步骤 4.配置编码&#xff08;使用库函数&#xff09; 5. 函数调用缩略图 1. USART框图 2. 传输帧图 起始位的特征&#xff1a;时钟引脚CK处于低电平&#xff0c;TX引脚处于低电平&#xff0c;持续1个SCLK长度&#xff08;位长度&…

2020-ICLR-Memory-Based Graph Networks

2020-ICLR-Memory-Based Graph Networks Paper&#xff1a;https://arxiv.org/abs/2002.09518 Code: https://github.com/amirkhas/GraphMemoryNet 基于内存的图网络 图神经网络&#xff08;GNN&#xff09;是一类可对任意拓扑结构的数据进行操作的深度模型。 作者为GNN引入了…

Python类调用实例方法

通常情况下&#xff0c;我们习惯使用类对象调用类中的实例方法。但如果想用类调用实例方法&#xff0c;不能像如下这样&#xff1a;class CLanguage: definfo(self): print("我正在学 Python") #通过类名直接调用实例方法 CLanguage.info()运行上面代码&#xff0c;程…

线路板行业含铜废水处理,铜箔废水深度处理和铜回收

产品介绍 传统沉淀法不能满足日益提的环保要求(如电镀表三镍含量要求0.1mg/l以下)。针对特定重金属离子的特点&#xff0c;利用螯合树脂的特种功能基团与重金属离子形成络合物的特性&#xff0c;实现重金属离子的回收利用及深度去除。 CH-90Na对除铜镍铅锌钴锰等具有特定的选择…

GBASE亮相第四代英特尔® 至强® 可扩展处理器新品发布

1月11日&#xff0c;英特尔&#xff08;中国&#xff09;有限公司成功举办“芯加速 行至远”——第四代英特尔发布会。GBASE南大通用作为英特尔的长期战略合作伙伴&#xff0c;双方联合推出GBase 8a大规模分布式并行处理&#xff08;MPP&#xff09;数据库集群系统解决方案&…

在spring boot3中使用native image

文章目录简介安装GraalVM添加Native Image支持构建spring boot3应用总结简介 在之前spring boot3文章中我们介绍了&#xff0c;spring boot3的一个重要特性就是支持把spring boot3的应用编译成为GraalVM的Native Image。 今天我们用具体的例子来给大家演示一下如何正确的将sp…

nacos 删除过期实例源码分析

nacos 删除过期实例也是注册中心的一个重要功能&#xff0c;今天我们从入口到结束分析一下&#xff0c;首先确定删除的入口在服务端注册接口的源码里&#xff0c;此处可以参考&#xff1a;参考注册源码 一、注册入口 1、创建空服务 public void registerInstance(String name…

行测笔记(主要知识点)

文章目录&#xff1a; 一&#xff1a;言语理解 1.技巧关系 2.逻辑填空 二&#xff1a;判断推理 1.图形推理 2.定义判断 3.类比推理 4.逻辑判断 三&#xff1a;资料分析 1.增长率 2.增长量 3.比重 4.平均数 5.倍数与比值 三&#xff1a;数量关系 1.解题…

Nozomi 交付业界第一个物联网端点安全传感器

运营技术 (OT) 和物联网 (IoT) 安全提供商 Nozomi Networks 推出了业界首款 OT 和物联网端点安全传感器 Nozomi Arc&#xff0c;旨在以指数方式加快实现完全运营弹性的时间。 Nozomi Arc 旨在自动部署在组织需要可见性的任何地方的大量站点和设备上&#xff0c;添加了关于关键…

六个步骤教你用Xmind制作思维导图

XMind是国产优秀的思维导图软件&#xff0c;那么如何使用xmind制作思维导图呢&#xff1f;对于新手来说&#xff0c;首先就要正确安装Xmind&#xff1b;其次&#xff0c;就是要搞清楚使用XMind画思维导图的步骤和方法&#xff0c;当然在学习使用xmind画思维导图的过程中也可以学…