快速上手:Prometheus和Grafana入门教程

news2024/9/22 17:30:07

目录

  • 一、简介
  • 二、安装Prometheus
    • 2.1 二进制安装
    • 2.2 添加到system服务
    • 2.3 访问UI
  • 三、安装Granfa
    • 3.1 Docker部署Mysql
    • 3.2 Docker部署Grafana
    • 3.3 访问UI
    • 3.4 添加Prometheus为数据源
  • 四、安装Exporter收集数据
    • 4.1 node_exporter 服务器监控
      • 下载解压
      • 启动node_exporter服务
      • 与整合Prometheus
      • 导入Grafana模版
    • 4.2 blackbox_exporter 接口存活监控
      • 下载解压
      • 启动blackbox_exporter服务
      • 与Prometheus整合
      • 导入Grafana模版
    • 4.3 mysqld_exporter 接口存活监控
      • 下载安装
      • 创建mysql新用户
      • 启动mysqld_exporter服务
      • 与Prometheus整合
      • 导入Grafana模版

一、简介

这篇博客详细介绍了如何安装和部署Prometheus和Grafana,以及如何使用它们来监控不同的应用程序和系统资源。还介绍了如何安装Prometheus的各种Exporter,并演示了如何使用node_exporter、blackbox_exporter和mysql_exporter来收集和展示不同的指标数据。利用Grafana提供的丰富的可视化功能,实现了对node、blackbox、mysql等应用程序的可视化监控。
如果您正在寻找一份详细的Prometheus和Grafana安装部署指南,以及如何使用它们来监控不同应用程序和系统资源的实用教程,本文将会是一个很好的参考。

二、安装Prometheus

2.1 二进制安装

github:https://github.com/prometheus/prometheus/releases/tag/v2.40.7

官网地址:https://prometheus.io

在这里插入图片描述
在这里插入图片描述

2.2 添加到system服务

注意修改ExecStart为你安装Prometheus的目录

cat <<-"EOF" > /etc/systemd/system/prometheus.service
[Unit]
Description="prometheus"
Documentation=https://prometheus.io/
After=network.target

[Service]
Type=simple
ExecStart=/data/prometheus/prometheus  --config.file=/data/prometheus/prometheus.yml --storage.tsdb.path=/data/prometheus/data --web.enable-lifecycle

Restart=on-failure
RestartSecs=5s
SuccessExitStatus=0
LimitNOFILE=655360
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=prometheus


[Install]
WantedBy=multi-user.target
EOF

执行命令启动prometheus服务

systemctl daemon-reload
systemctl restart prometheus
systemctl status prometheus

# 查看端口 进程 日志
ss -ntlp |grep 9090
ps -ef |grep prometheus |grep -v grep 

tail -100  /var/log/messages |grep prometheus

在这里插入图片描述
在这里插入图片描述

2.3 访问UI

浏览器访问IP+9090端口

在这里插入图片描述

三、安装Granfa

github:https://github.com/grafana/grafana

创建映射目录

cd /data
mkdir -p grafana-server/
cd grafana-server/
mkdir -p etc/
mkdir -p mysql/data
mkdir -p grafana/data

拉取镜像

docker pull mysql:8.0
docker pull grafana/grafana

3.1 Docker部署Mysql

创建mysql docker容器

docker run -p 33060:3306 --name mysql8 \
-v /data/grafana-server/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
-e  MYSQL_DATABASE=grafana \
-e  MYSQL_USER=grafana \
-e  MYSQL_PASSWORD=123456 \
-e  TZ=Asia/Shanghai \
--restart=always \
-d mysql:8.0

192.168.153.128是我的宿主机IP。我将mysql容器的3306端口映射到了宿主机的33060端口

测试连接

在这里插入图片描述
在这里插入图片描述

3.2 Docker部署Grafana

将grafana容器内的grafana配置文件拷贝出来

docker run -itd --name grafana-server grafana/grafana:latest
docker cp grafana-server:/var/lib/grafana /data/grafana-server/grafana/data/
docker stop grafana-server
docker rm grafana-server

编辑grafana配置文件修改存储库为mysql

vim /data/grafana-server/etc/grafana.ini
[database]
# You can configure the database connection by specifying type, host, name, user and password
# as separate properties or as on string using the url properties.

# Either "mysql", "postgres" or "sqlite3", it's your choice
type = mysql
host = 192.168.153.128:33060
name = grafana
user = grafana
# If the password contains # or ; you have to wrap it with triple quotes. Ex """#password;"""
password = 123456

# Use either URL or the previous fields to configure the database
# Example: mysql://user:secret@host:port/database
; url = mysql://grafana:grafana_123@192.168.153.128:33060/grafana
max_idle_conn = 2

# Max conn setting default is 0 (mean not set)
max_open_conn = 100

# Connection Max Lifetime default is 14400 (means 14400 seconds or 4 hours)
conn_max_lifetime = 600

创建容器

docker run -p 3000:3000 --name grafana \
-v /data/grafana-server/grafana/data/grafana:/var/lib/grafana \
-v /data/grafana-server/etc/grafana.ini:/etc/grafana/grafana.ini \
-v /etc/localtime:/etc/localtime \
--restart=always \
-d grafana/grafana
docker ps |grep grafana

docker stop grafana

docker rm grafana

docker logs grafana

3.3 访问UI

浏览器访问IP+3000端口
初始用户名:admin
初始密码:admin

登录后提示修改密码,也可以不修改,点击skip跳过。

在这里插入图片描述
在这里插入图片描述

3.4 添加Prometheus为数据源

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

四、安装Exporter收集数据

4.1 node_exporter 服务器监控

下载解压

Github:https://github.com/prometheus/node_exporter/releases
在这里插入图片描述

解压压缩包,重命名文件

tar -zxvf node_exporter-1.5.0.linux-arm64.tar.gz 
mv node_exporter-1.5.0.linux-arm64 node_exporter

在这里插入图片描述

启动node_exporter服务

修改ExecStart为解压目录,然后直接粘贴回车。

cat <<EOF> /etc/systemd/system/node_exporter.service
[Unit]
Description=Node Exporter
Wants=network-online.target
After=network-online.target

[Service]
ExecStart=/data/prometheus-exporter/node_exporter/node_exporter
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=node_exporter
[Install]
WantedBy=default.target

EOF

执行命令启动node_exporter服务

systemctl daemon-reload
systemctl restart node_exporter
systemctl status node_exporter

与整合Prometheus

进入Prometheus安装目录,修改prometheus.yaml文件
在这里插入图片描述

更新Prometheus数据

# Prometheus 热更新命令
curl -vvv  -X POST localhost:9090/-/reload

在这里插入图片描述

导入Grafana模版

https://grafana.com/grafana/dashboards/1860-node-exporter-full/
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4.2 blackbox_exporter 接口存活监控

下载解压

Github:https://github.com/prometheus/node_exporter/releases

启动blackbox_exporter服务

cat <<EOF> /etc/systemd/system/blackbox_exporter.service
[Unit]
Description=blackbox_exporter Exporter
Wants=network-online.target
After=network-online.target

[Service]
ExecStart=/data/prometheus-exporter/blackbox_exporter/blackbox_exporter --config.file=/data/prometheus-exporter/blackbox_exporter/blackbox.yml
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=blackbox_exporter
[Install]
WantedBy=default.target
EOF

执行以下命令启动blackbox_exporter服务

systemctl daemon-reload
systemctl restart blackbox_exporter
systemctl status blackbox_exporter

启动以后可以使用http://192.168.153.128:9115/probe?target=https://www.baidu.com&module=http_2xx&debug=true进行验证(注意换成你的IP访问)

与Prometheus整合

编辑prometheus.yaml文件:

  - job_name: 'blackbox-http'
    metrics_path: /probe
    params:
      module: [http_2xx]  # Look for a HTTP 200 response.
    static_configs:
      - targets:
        - http://prometheus.io
        - https://www.baidu.com
        - http://www.google.com
        - http://192.168.153.129:31064/hello
    relabel_configs:
      - source_labels: [__address__]
        target_label: __param_target
      - source_labels: [__param_target]
        target_label: instance
      - target_label: __address__
        replacement: 127.0.0.1:9115  

更新Prometheus数据

curl -vvv  -X POST localhost:9090/-/reload

导入Grafana模版

Grafana 模版:https://grafana.com/grafana/dashboards/13659
在这里插入图片描述

4.3 mysqld_exporter 接口存活监控

下载安装

https://github.com/prometheus/mysqld_exporter/releases/tag/v0.14.0

tar -zxvf mysqld_exporter-0.14.0.linux-arm64.tar.gz
mv mysqld_exporter-0.14.0.linux-arm64 mysqld_exporter

创建mysql新用户

# 登陆mysql
 mysql -uroot -p123456
# 创建exporter用户
CREATE USER 'exporter'@'%' IDENTIFIED BY '123456' ;
GRANT PROCESS, REPLICATION CLIENT, SELECT ON *.* TO 'exporter'@'%';
FLUSH PRIVILEGES;

在这里插入图片描述

启动mysqld_exporter服务

修改 Environment 和 ExecStart 值,然后直接粘贴回车

cat <<EOF> /etc/systemd/system/mysqld_exporter.service
[Unit]
Description=mysqld_exporter Exporter
Wants=network-online.target
After=network-online.target

[Service]
Environment=DATA_SOURCE_NAME=exporter:123456@(192.168.153.128:33060)/
ExecStart=/data/prometheus-exporter/mysqld_exporter/mysqld_exporter
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=mysqld_exporter
[Install]
WantedBy=default.target
EOF

执行命令启动mysqld_exporter服务

systemctl daemon-reload
systemctl restart mysqld_exporter

启动服务后可以访问http://192.168.153.128:9104/进行验证:
在这里插入图片描述

与Prometheus整合

修改prometheus.yml文件

  - job_name: mysqld_exporter
    honor_timestamps: true
    scrape_interval: 8s
    scrape_timeout: 8s
    metrics_path: /metrics
    scheme: http
    follow_redirects: true
    static_configs:
    - targets:
      - 192.168.153.128:9104

更新Prometheus数据

curl -vvv  -X POST localhost:9090/-/reload

导入Grafana模版

https://grafana.com/grafana/dashboards/11323

导入模版以后需要修改host变量
在这里插入图片描述
在这里插入图片描述

修改 Hide 为Label
在Query中 删除大括号里面的变量
保存退出即可
在这里插入图片描述

在这里插入图片描述

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

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

相关文章

聚类-理论补充2

目录 一。拉普拉斯矩阵的定义 二。谱聚类算法&#xff1a;未正则拉普拉斯矩阵 三。谱聚类算法&#xff1a;随机游走拉普拉斯矩阵 四。谱聚类算法&#xff1a;对称拉普拉斯矩阵 五。进一步思考 六。随机游走和拉普拉斯矩阵的关系 七。标签传递算法 一。拉普拉斯矩阵的定义 …

MySQL(六)

查询优化 在编写快速的查询之前&#xff0c;需要清楚一点&#xff0c;真正重要的是响应时间&#xff0c;而且要知道在整个SQL语句的执行过程中每个步骤都花费了多长时间&#xff0c;要知道哪些步骤是拖垮执行效率的关键步骤&#xff0c;想要做到这点&#xff0c;必须要知道查询…

Qt之调色板类QPalette的使用

文章目录QPalette调色板类前言代码知识点讲解QPalette调色板类 前言 Qt提供的调色板类QPalette专门用于管理部件的外观显示&#xff0c;相当于部件或对话框的调色板&#xff0c;管理他们所有的颜色信息。每个部件都包含一个QPalette对象&#xff0c;在显示时&#xff0c;按照…

OnGUI Color 控件||Unity 3D GUI 简介||OnGUI TextField 控件

Unity 3D Color 控件与 Background Color 控件类似&#xff0c;都是渲染 GUI 颜色的&#xff0c;但是两者不同的是 Color 不但会渲染 GUI 的背景颜色&#xff0c;同时还会影响 GUI.Text 的颜色。具体使用时&#xff0c;要作如下定义&#xff1a;public static var color:Color;…

Go 管道关闭引发的探索

前言 在日常开发中, 经常会使用chan来进行协程之间的通信. 对chan的操作也无外乎读写关. 而本次, 就是从chan的关闭而来. 假设我们对外提供的方法如下: type Chan struct {ch chan int }func (c *Chan) Close() {close(c.ch) }func (c *Chan) Send(v int) {c.ch <- v }那…

Qt 工程师进阶技术23种设计模式

Qt 工程师进阶技术23种设计模式【1】23种设计模式【1】23种设计模式 设计模式是解决特定问题的一系列套路&#xff0c;这套方案提高代码可复用性、可读性、稳健性、可维护性及安全性。 23种设计模式可分为三类:结构型模式(侧重类与对象之间的组合)、行为型模式&#xff08;侧重…

day47【代码随想录】动态规划之买卖股票的最佳时机III、买卖股票的最佳时机IV、最佳买卖股票时机含冷冻期、买卖股票的最佳时机含手续费

文章目录前言一、买卖股票的最佳时机III&#xff08;力扣123&#xff09;二、买卖股票的最佳时机IV&#xff08;力扣188&#xff09;三、最佳买卖股票时机含冷冻期&#xff08;力扣309&#xff09;四、买卖股票的最佳时机含手续费&#xff08;力扣714&#xff09;股票买卖问题总…

office365 word 另存为 pdf 的注意事项和典型设置

0. 操作环境介绍 Office 版本&#xff1a;Office 365 版本 不同版本的操作可能有所不同 1. 基本操作 – 另存为 pdf 【文件】 --> 【另存为】&#xff0c;选择适当的文件路径、文件名保存类型选择【PDF】点击【保存】 1. 导出的pdf包含目录标签 word中&#xff0c;可使用…

Head First设计模式---1.策略模式

4.1策略模式&#xff1a; 策略模式是一种行为设计模式&#xff0c; 它能让你定义一系列算法&#xff0c; 并将每种算法分别放入独立的类中&#xff0c; 以使算法的对象能够相互替换。 问题 一天&#xff0c;我们需要做一个鸭子游戏&#xff0c;游戏中会出现各种鸭子&#xff…

掘金数据时代2022年度隐私计算评选活动火热报名中!

开放隐私计算 开放隐私计算开放隐私计算OpenMPC是国内第一个且影响力最大的隐私计算开放社区。社区秉承开放共享的精神&#xff0c;专注于隐私计算行业的研究与布道。社区致力于隐私计算技术的传播&#xff0c;愿成为中国 “隐私计算最后一公里的服务区”。183篇原创内容公众号…

全网最全虚拟机的封装

1.服务器初始化 系统环境RHEL7.6 2.禁用selinux [rootserver1 ~]# vim /etc/sysconfig/selinux SELINUXdisabled reboot 3.禁用防火墙 [rootserver1 ~]# systemctl disable --now firewalld 4.配置yum源 [rootserver1 ~]# vim /etc/fstab /dev/mapper/rhel…

AC的改进算法——TRPO、PPO

两类AC的改进算法 整理了动手学强化学习的学习内容 1. TRPO 算法&#xff08;Trust Region Policy Optimization&#xff09; 1.1. 前沿 策略梯度算法即沿着梯度方向迭代更新策略参数 。但是这种算法有一个明显的缺点&#xff1a;当策略网络沿着策略梯度更新参数&#xff0c…

(考研湖科大教书匠计算机网络)第五章传输层-第五节:TCP拥塞控制

获取pdf&#xff1a;密码7281专栏目录首页&#xff1a;【专栏必读】考研湖科大教书匠计算机网络笔记导航 文章目录一&#xff1a;拥塞控制概述二&#xff1a;拥塞控制四大算法&#xff08;1&#xff09;慢开始和拥塞避免A&#xff1a;慢启动&#xff08;slow start&#xff09;…

CTFer成长之路之举足轻重的信息搜集

举足轻重的信息搜集CTF 信息搜集 常见的搜集 题目描述: 一共3部分flag docker-compose.yml version: 3.2services:web:image: registry.cn-hangzhou.aliyuncs.com/n1book/web-information-backk:latestports:- 80:80启动方式 docker-compose up -d 题目Flag n1book{in…

设计模式-代理模式

控制和管理访问 玩过扮白脸&#xff0c;扮黑脸的游戏吗&#xff1f;你是一个白脸&#xff0c;提供很好且很友善的服务&#xff0c;但是你不希望每个人都叫你做事&#xff0c;所以找了黑脸控制对你的访问。这就是代理要做的&#xff1a;控制和管理对象。 监视器编码 需求&…

数据挖掘,计算机网络、操作系统刷题笔记49

数据挖掘&#xff0c;计算机网络、操作系统刷题笔记49 2022找工作是学历、能力和运气的超强结合体&#xff0c;遇到寒冬&#xff0c;大厂不招人&#xff0c;可能很多算法学生都得去找开发&#xff0c;测开 测开的话&#xff0c;你就得学数据库&#xff0c;sql&#xff0c;orac…

Spring Cloud Alibaba 微服务简介

微服务简介 1 什么是微服务 2014年&#xff0c;Martin Fowler&#xff08;马丁福勒 &#xff09; 提出了微服务的概念&#xff0c;定义了微服务是由以单一应用程序构成的小服务&#xff0c;自己拥有自己的进程与轻量化处理&#xff0c;服务依业务功能设计&#xff0c;以全自动…

将Nginx 核心知识点扒了个底朝天(四)

为什么 Nginx 不使用多线程&#xff1f; Apache: 创建多个进程或线程&#xff0c;而每个进程或线程都会为其分配 cpu 和内存&#xff08;线程要比进程小的多&#xff0c;所以 worker 支持比 perfork 高的并发&#xff09;&#xff0c;并发过大会榨干服务器资源。 Nginx: 采用…

程序员35岁中年危机不是坎,是一把程序员自己设计的自旋锁

有时候&#xff0c;我会思考35岁这个程序员的诅咒&#xff0c;确切来说是中国程序员的独有的诅咒。 优秀的程序员思维逻辑严谨&#xff0c;弄清楚需求的本质是每天重复的工作&#xff0c;也是对工作的态度&#xff0c;那弄清楚诅咒的来源&#xff0c;义不容辞。 被诅咒的35岁 …

【爬虫】自动获取showdoc指定项目中的所有文档

▒ 目录 ▒&#x1f6eb; 导读需求1️⃣ 格式分析官方下载文件内容prefix_info.json文件格式2️⃣ 封包分析/api/page/info/api/item/info3️⃣ 编码代码特点问题&#x1f4d6; 参考资料&#x1f6eb; 导读 需求 showdoc是一个API文档、技术文档工具网站&#xff0c;经常能搜到…