Prometheus部署

2023-10-30

目录

一、部署prometheus

1,环境准备工作

2、普罗米修斯的部署

2.1 上传prometheus到、opt目录中,解压

2.2 修改配置文件

2.3 配置系统启动文件,设置开机自启

2.4 开启prometheus,并访问网页验证

二、部署Exporters(192.168.187.68)

1,监控远程Linux主机192.168.187.68

1.1上传node_exporter到opt目录中,并且解压

1.2 启动node_exporter

1.3 修改prometheus服务器的配置文件

1.5 访问prometheus服务器

2、监控远程mysql

3、配置Prometheus获取监控数据

三、部署Grafana进行展示

1、下载安装Grafana


一、部署prometheus

1,环境准备工作

服务器类型 IP地址 组件
prometheus服务器 192.168.187.48 prometheus,node_exporter
mysql服务器 192.168.187.78 mysql——exporter和mariadb
agent服务器 192.168.187.68 node-exporter
agent服务器 192.168.187.108 node-exporter
Grafana服务器 192.168.187.98 Grafana

2、普罗米修斯的部署

prometheus下载地址:

https://prometheus.io/download/

2.1 上传prometheus到、opt目录中,解压

[root@pro1 ~]#cd /opt
[root@pro1 opt]#rz -E
rz waiting to receive.
[root@pro1 opt]#ls
ELK  fdisk.sh  gfsrepo  mysql-5.7.20  mysql_all.sql  prometheus-2.27.1.linux-amd64.tar.gz  rh
[root@pro1 opt]#tar zxvf prometheus-2.27.1.linux-amd64.tar.gz
[root@pro1 opt]#ls
ELK       gfsrepo       mysql_all.sql                  prometheus-2.27.1.linux-amd64.tar.gz
fdisk.sh  mysql-5.7.20  prometheus-2.27.1.linux-amd64  rh
[root@pro1 opt]#mv prometheus-2.27.1.linux-amd64 /usr/local/prometheus
[root@pro1 opt]#cd /usr/local/prometheus/
[root@pro1 prometheus]#ls
console_libraries  consoles  LICENSE  NOTICE  prometheus  prometheus.yml  promtool

2.2 修改配置文件

[root@pro1 prometheus]#vim /usr/local/prometheus/prometheus.yml

# my global config
global:
  scrape_interval:     15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
  evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
  # scrape_timeout is set to the global default (10s).

# Alertmanager configuration
alerting:
  alertmanagers:
  - static_configs:
    - targets:
      # - alertmanager:9093

# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
rule_files:
  # - "first_rules.yml"
  # - "second_rules.yml"

# A scrape configuration containing exactly one endpoint to scrape:
# Here it's Prometheus itself.
scrape_configs:
  # The job name is added as a label `job=<job_name>` to any timeseries scraped from this config.
  - job_name: 'prometheus'

    # metrics_path defaults to '/metrics'
    # scheme defaults to 'http'.

    static_configs:
    - targets: ['192.168.187.48:9090']

2.3 配置系统启动文件,设置开机自启

[root@pro1 prometheus]#vim /usr/lib/systemd/system/prometheus.service

[Unit]
Description=Prometheus Server
Documentation=https://prometheus.io
After=network.target
 
[Service]
Type=simple
ExecStart=/usr/local/prometheus/prometheus \
--config.file=/usr/local/prometheus/prometheus.yml \
--storage.tsdb.path=/usr/local/prometheus/data/ \
--storage.tsdb.retention=15d \
--web.enable-lifecycle
  
ExecReload=/bin/kill -HUP $MAINPID
Restart=on-failure
 
[Install]
WantedBy=multi-user.target

2.4 开启prometheus,并访问网页验证

systemctl start prometheus
systemctl enable prometheus
 
netstat -natp | grep :9090
 
浏览器访问:http://192.168.187.48:9090 ,访问到 Prometheus 的 Web UI 界面
点击页面的 Status -> Targets,如看到 Target 状态都为 UP,说明 Prometheus 能正常采集到数据
http://192.168.187.48:9090/metrics ,可以看到 Prometheus 采集到自己的指标数

通过http:// 192.168.187.48/metrics 可以查看到监控的数据:

二、部署Exporters(192.168.187.68)

1,监控远程Linux主机192.168.187.68

在远程linux主机(被监控端agent)上安装node_exporter组件

下载地址

https://prometheus.io/download/

1.1上传node_exporter到opt目录中,并且解压

[root@grafana ~]#cd /opt
[root@grafana opt]#rz -E
rz waiting to receive.
[root@grafana opt]#ls
mysql-5.7.20  node_exporter-1.1.2.linux-amd64.tar.gz  rh
[root@grafana opt]#tar zxvf node_exporter-1.1.2.linux-amd64.tar.gz
node_exporter-1.1.2.linux-amd64/
node_exporter-1.1.2.linux-amd64/LICENSE
node_exporter-1.1.2.linux-amd64/NOTICE
node_exporter-1.1.2.linux-amd64/node_exporter
[root@grafana opt]#ls
mysql-5.7.20  node_exporter-1.1.2.linux-amd64  node_exporter-1.1.2.linux-amd64.tar.gz  rh
[root@grafana opt]#mv node_exporter-1.1.2.linux-amd64 /usr/local/bin
[root@grafana opt]#cd /usr/local/bin/node_exporter-1.1.2.linux-amd64/
[root@grafana node_exporter-1.1.2.linux-amd64]#ls
LICENSE  node_exporter  NOTICE

1.2 启动node_exporter

./node_exporter  #执行脚本


netstat -natp | grep :9100


浏览器访问:http://192.168.109.20:9100/metrics ,可以看到 Node Exporter 采集到的指标数值

1.3 修改prometheus服务器的配置文件

[root@pro1 prometheus]#vim /usr/local/prometheus/prometheus.yml
 - job_name: 'agent'
   static_configs:
   - targets: ['192.168.187.68:9100']

重启服务  

1.5 访问prometheus服务器

回到 web 管理界面→点 Status→点 Targets→可以看到多了一台监控目标

2、监控远程mysql

在 192.168.187.78上安装 mysqld_exporter组件

mysqld_exporter 是 Prometheus 的 MySQL 指标导出插件。Github 地址:GitHub - prometheus/mysqld_exporter: Exporter for MySQL server metrics。这里来演示它的部署。

[root@mysql opt]#tar zxvf mysqld_exporter-0.12.1.linux-amd64.tar.gz -C /usr/local
[root@mysql opt]#cd /usr/local/
[root@mysql local]#mv mysqld_exporter-0.12.1.linux-amd64/ mysqld_exporter 

在mysql中创建监控用户,并赋权

create user 'exporter'@'localhost'  IDENTIFIED BY '123456';

GRANT SELECT, PROCESS, SUPER, REPLICATION CLIENT, RELOAD ON *.* TO 'exporter'@'localhost';

为mysqld_exporter 创建个配置文件

vim /usr/local/mysqld_exporter/mysqld_exporter.cnf

启动组件 

nohup /usr/local/mysqld_exporter/mysqld_exporter  --config.my-cnf=/usr/local/mysqld_exporter/mysqld_exporter.cnf &

浏览器访问一下默认端口为9104

3、配置Prometheus获取监控数据

在Prometheus的配置文件中添加node_exporter 和 mysqld_exporter 的配置

然后重启一下 重新访问

看到新增的被监控节点,就是说明配置成功

会主界面搜索 MySQL 相关参数,比如:mysql_global_variables_auto_increment_increment

三、部署Grafana进行展示

Grafana 是一个开源的度量分析和可视化工具,可以通过将采集的数据分析,查询,然后进行可视化的展示,并能实现报警。

下载地址

https://grafana.com/grafana/download/

1、下载安装Grafana

#使用yum解决依赖关系  我这边直接上传软件包到opt
yum install -y grafana-7.4.0-1.x86_64.rpm 或
mkdir /mnt/grafana

cd /mnt/grafana

上传安装包
rpm -ivh grafana-7.3.6-1.x86_64.rpm 解压
 
systemctl start grafana-server
systemctl enable grafana-server
netstat -natp | grep :3000

#账号密码默认为admin,admin
grafana默认配置文件目录 /etc/grafana/grafana.ini
浏览器访问:http://192.168.187.98:3000 ,默认账号和密码为 admin/admin

 

 

 

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Prometheus部署 的相关文章

随机推荐

  • Java学习笔记-多线程实现方式

    Java学习笔记 多线程实现方式 注意 线程开启不一定立即执行 由CPU调度执行 1 继承Thread类 自定义线程类继承Thread类 重写run 方法 编写线程执行体 创建线程对象 调用start 方法启动线程 public class
  • [leetcode 周赛 149] 1157 子数组中占绝大多数的元素

    目录 1157 Online Majority Element In Subarray 子数组中占绝大多数的元素 描述 思路 代码实现 1157 Online Majority Element In Subarray 子数组中占绝大多数的元
  • 第七届蓝桥杯大赛个人赛省赛(软件类 C语言b组)真题 (个人解题思路)

    1 煤球数目 有一堆煤球 堆成三角棱锥形 具体 第一层放1个 第二层3个 排列成三角形 第三层6个 排列成三角形 第四层10个 排列成三角形 如果一共有100层 共有多少个煤球 请填表示煤球总数目的数字 注意 你提交的应该是一个整数 不要填
  • Zabbix基础概念及原理

    Zabbix Zabbix基础概念及原理 什么是zabbix 功能组件 Server 数据库 Web界面 Proxy agent 监控功能 zabbix工作原理 zabbix工作进程 zabbix agentd zabbix get zab
  • LeetCode题解-让所有学生保持开心的分组方法数

    简单说两句 作者 后端小知识 CSDN个人主页 后端小知识 GZH 后端小知识 欢迎关注 点赞 收藏 留言 亲爱的各位友友们 今天来给大家讲解一道力扣中等题 废话不多说 接下面我就浅浅分析下这个题吧 我一定能给你讲明白的 我们先来康康题目的
  • 字符串循环右移

    题目内容 输入一个字符串和一个非负整数N 要求将字符串循环右移N次 输入格式 输入在第1行中给出一个字符串 以 表示结束
  • LVDS接口和LVDS技术

    LVDS接口 目前6 5寸及以上尺寸的液晶屏大多都是LVDS接口的了 而LVDS接口的屏主要是应用于工控行业 如下图就是LVDS接口的使用场景 下图所示为五通道LVDS发送芯片 DS90C385 内部框图 包含了四个数据信号 其中包括RGB
  • Arduino 读取并数码显示车速传感器数

    材料 介绍 7 段显示器上的背板允许它使用 I2C 协议 也称为两线接口 由 Arduino 控制 如果没有 I2C 背板 您将必须直接控制每个数字的所有八个部分 这将耗尽 Arduino 上的所有引脚 或者您必须找出其他一些可能最终与 A
  • ubuntu安装zip工具解压zip压缩包,Package zip is not available, but is referred to by another package.

    apt get install zip 今天在ubuntu进行zip安装的时候 出现如下错误 Reading package lists Done Building dependency tree Done Package zip is n
  • Ubuntu16.04安装网卡驱动

    1 根据电脑网卡型号 查找对应的驱动 2 若是在Linux中安装驱动 要注意内核版本 3 具体操作参考Ubuntu 16 04 手动安装无线网卡驱动 连接WiFi
  • HarmonyOS 鸿蒙

    HarmonyOS是一款 面向未来 面向全场景 移动办公 运动健康 社交通信 媒体娱乐等 的分布式操作系统 在传统的单设备系统能力的基础上 HarmonyOS提出了基于同一套系统能力 适配多种终端形态的分布式理念 能够支持多种终端设备 通知
  • 4-0 特征选择简述

    第4章 特征选择 4 0 特征选择简述 请参考 数据准备和特征工程 中的相关章节 调试如下代码 import pandas as pd df wine pd read csv home aistudio data data20527 win
  • [踩坑记录] Unresolved reference: viewModels() 和 Unresolved reference: activityViewModels()

    解决无法使用by viewModels by activityViewModels 安卓开发过程使用kotlin开发LiveData和ViewModel时 有时候会遇到 Unresolved reference viewModels Unr
  • OpenCV-Python图像颜色变换

    给图像添加颜色 在使用OpenCV操作图像时 有时候需要给图像添加不同的颜色 以达到不同的风格效果 这里介绍的主要是opencv中的cv applyColorMap 函数 给图像应用颜色函数cv applyColorMap src colo
  • SpringMVC复习总结

    一 SpringMVC简介 1 什么是SpringMVC MVC是什么 MVC是一种软件架构的思想 将软件按照模型 视图 控制器来划分 M Model 模型层 指工程中的JavaBean 作用是处理数据 JavaBean分为两类 一类称为实
  • vue之web3.js开发之错误:Uncaught (in promise) TypeError: Cannot read property 'node

    这个问题的意思就是找不到node节点的意思 init web3 1 0 version this web3 new Web3 Web3 givenProvider new Web3 providers HttpProvider http 1
  • C# 重写WndProc 消息循环

    重写WndProc方法来处理 Windows 消息 处理 Windows 消息 在开发winForm时 常常要处理Windows消息 可以重写WndProc来实现 常见代码如下 using System using System Drawi
  • mac m1 mysqlworkbench8 Unknown table ‘COLUMN_STATISTICS‘

    原因 本地mysql版本是8 远程是mariaDb 10 版本不匹配导致报错 仔细看mysqlworkbench8 0导出时的错误信息 有mysqldump的具体路径 mac os m1 ventura系统 具体位置是这里 Applicat
  • 获取当前季度、前N季度、判断时间是否超出该季度

    获取当前季度 前N个季度的值 指定时间和季度 来判断该事件是否超出了该季度 ClassName QuarterUtil Description 季度工具类 public class QuarterUtil private static fi
  • Prometheus部署

    目录 一 部署prometheus 1 环境准备工作 2 普罗米修斯的部署 2 1 上传prometheus到 opt目录中 解压 2 2 修改配置文件 2 3 配置系统启动文件 设置开机自启 2 4 开启prometheus 并访问网页验