news 2026/4/23 17:44:50

在Linux系统上安装和使用Prometheus+Grafana

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
在Linux系统上安装和使用Prometheus+Grafana

我们将会介绍如何在Linux系统上安装和使用Prometheus,包括以下步骤:

  1. 下载和安装Prometheus
  2. 配置Prometheus
  3. 启动Prometheus服务器
  4. 访问Prometheus的Web界面
  5. 配置Prometheus监控自身
  6. 安装和配置Node Exporter(用于监控Linux主机)
  7. 配置Prometheus抓取Node Exporter
  8. 使用PromQL查询数据
  9. 集成Grafana进行数据可视化

注意:以下操作以Ubuntu系统为例,但同样适用于其他Linux发行版。

步骤1:下载和安装Prometheus

前往Prometheus官方网站下载页面(https://prometheus.io/download/)获取最新版本的Prometheus。 或者直接在服务器上使用wget下载。

假设我们使用64位的Linux系统,可以执行以下命令:

# 创建目录并进入 mkdir -p ~/prometheus-setup cd ~/prometheus-setup # 下载Prometheus wget https://github.com/prometheus/prometheus/releases/download/v2.30.3/prometheus-2.30.3.linux-amd64.tar.gz # 注意:请检查官网以获取最新版本,替换上面的版本号 # 解压 tar xvfz prometheus-*.tar.gz # 进入解压后的目录 cd prometheus-*

步骤2:配置Prometheus

Prometheus的配置文件是prometheus.yml。默认的配置文件已经包含了监控Prometheus自身的配置。

我们可以先查看默认配置:

cat prometheus.yml

默认配置可能如下:

# 全局配置 global: scrape_interval: 15s # 默认每15秒抓取一次 evaluation_interval: 15s # 每15秒评估一次规则 # 告警配置 alerting: alertmanagers: - static_configs: - targets: # - alertmanager:9093 # 规则文件 rule_files: # - "first_rules.yml" # - "second_rules.yml" # 抓取配置 scrape_configs: # 监控Prometheus自身 - job_name: 'prometheus' static_configs: - targets: ['localhost:9090']

步骤3:启动Prometheus服务器

使用以下命令启动Prometheus:

# 启动Prometheus,并指定配置文件 ./prometheus --config.file=prometheus.yml

启动后,Prometheus默认会监听9090端口。

步骤4:访问Web界面

在浏览器中访问:http://<服务器的IP地址>:9090

在Web界面中,我们可以查看Prometheus的状态、执行查询等。

步骤5:配置Prometheus监控自身

默认配置中已经包含了监控自身的job,所以无需额外配置。

步骤6:安装和配置Node Exporter

Node Exporter用于暴露主机的硬件和操作系统指标。下载并安装:

# 返回上级目录 cd ~/prometheus-setup # 下载Node Exporter wget https://github.com/prometheus/node_exporter/releases/download/v1.2.2/node_exporter-1.2.2.linux-amd64.tar.gz # 解压 tar xvfz node_exporter-*.tar.gz # 进入目录 cd node_exporter-*

启动Node Exporter:

./node_exporter

Node Exporter默认监听9100端口。

步骤7:配置Prometheus抓取Node Exporter

修改Prometheus的配置文件prometheus.yml,在scrape_configs部分添加新的job:

scrape_configs: - job_name: 'prometheus' static_configs: - targets: ['localhost:9090'] # 添加Node Exporter - job_name: 'node_exporter' static_configs: - targets: ['localhost:9100'] # 如果Node Exporter运行在同一台机器上

重启Prometheus使配置生效(先按Ctrl+C停止,然后重新启动)。

步骤8:使用PromQL查询数据

在Web界面中,我们可以输入PromQL查询表达式。例如:

  • 查看所有指标:http_requests_total
  • 查看CPU使用率:100 - (avg by (instance) (irate(node_cpu_seconds_total{mode="idle"}[5m])) * 100)
  • 查看内存使用:node_memory_MemTotal_bytes - node_memory_MemFree_bytes

步骤9:集成Grafana

安装Grafana(这里以Ubuntu为例):

sudo apt-get install -y apt-transport-https sudo apt-get install -y software-properties-common wget wget -q -O - https://packages.grafana.com/gpg.key | sudo apt-key add - echo "deb https://packages.grafana.com/oss/deb stable main" | sudo tee -a /etc/apt/sources.list.d/grafana.list sudo apt-get update sudo apt-get install grafana

启动Grafana服务:

sudo systemctl daemon-reload sudo systemctl start grafana-server sudo systemctl enable grafana-server

Grafana默认监听3000端口,访问http://<服务器IP>:3000,默认用户名和密码为admin/admin。

添加数据源:

登录Grafana web ui 界面,点击左边框“配置”按钮,选择“Data Source”,选择“Add data source”

  • 选择Prometheus
  • URL填写http://localhost:9090(如果Grafana和Prometheus在同一台机器)

然后可以导入现成的仪表盘模板,例如Node Exporter的仪表盘,模板ID为1860。

这样,我们就完成了Prometheus的安装、配置,以及Node Exporter的安装和Grafana的集成。

注意:置开机启动。

下面提供将Prometheus和Node Exporter配置为系统服务的示例(Ubuntu系统):

创建Prometheus系统服务文件:

sudo nano /etc/systemd/system/prometheus.service

内容如下(请根据实际路径修改):

[Unit] Description=Prometheus Wants=network-online.target After=network-online.target [Service] User=prometheus Group=prometheus Type=simple ExecStart=/home/your_user/prometheus-setup/prometheus-2.30.3.linux-amd64/prometheus \ --config.file /home/your_user/prometheus-setup/prometheus-2.30.3.linux-amd64/prometheus.yml \ --storage.tsdb.path /home/your_user/prometheus-setup/data [Install] WantedBy=multi-user.target

创建Node Exporter系统服务文件:

sudo nano /etc/systemd/system/node_exporter.service

内容如下:

[Unit] Description=Node Exporter Wants=network-online.target After=network-online.target [Service] User=prometheus Group=prometheus Type=simple ExecStart=/home/your_user/prometheus-setup/node_exporter-1.2.2.linux-amd64/node_exporter [Install] WantedBy=multi-user.target

注意:建议创建一个专门的用户来运行这些服务:

sudo useradd --no-create-home --shell /bin/false prometheus

并修改对应目录的权限。

最后,重新加载systemd并启用服务:

sudo systemctl daemon-reload sudo systemctl enable prometheus.service sudo systemctl start prometheus.service sudo systemctl enable node_exporter.service sudo systemctl start node_exporter.service

这样,即使服务器重启,服务也会自动启动。

以上就是在Linux系统上安装和使用Prometheus的完整步骤。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 16:15:06

深入SolidJS的响应式更新机制

引言 在SolidJS的世界里,响应式编程是一个核心的概念,它使得状态的变化能够自动触发视图的更新。然而,当我们深入了解这个机制时,可能会遇到一些意想不到的行为。本文将通过一个实际的代码示例来探讨SolidJS中状态更新的细微差别。 示例代码 我们先来看一段代码,它展示…

作者头像 李华
网站建设 2026/4/23 16:12:39

揭秘Amazon DMS中的时间转换怪象

引言 在使用Amazon Database Migration Service (DMS)进行MySQL/MariaDB数据库的持续复制时,许多用户发现TIME数据类型的字段在迁移过程中出现了奇怪的变形。例如,13:22:31可能会被转换为112:16:02或者-911:43:62,这种问题不仅影响了数据的准确性,更是让开发者头疼不已。本…

作者头像 李华
网站建设 2026/4/23 12:21:43

Linux如何检测网络带宽使用率?

在Linux运维工作中&#xff0c;网络带宽使用率是判断系统网络状态的核心指标&#xff0c;不管是排查网络卡顿问题&#xff0c;还是优化服务器数据传输效率&#xff0c;都离不开对它的精准监测。那么Linux如何检测网络带宽使用率?具体请看下文。iftop&#xff1a;实时查看网络连…

作者头像 李华
网站建设 2026/4/23 12:13:26

前端转渗透测试靠谱吗?挖漏洞到底能不能赚到钱?

最近&#xff0c;一个做运维的朋友在学渗透测试。他说&#xff0c;他公司请别人做渗透测试的费用是 2w/人天&#xff0c;一共2周。2周 10w 的收入&#xff0c;好香~ ​ 于是&#xff0c;我也对渗透测试产生了兴趣。开始了探索之路~ 什么是渗透测试 渗透测试这名字听起来有一…

作者头像 李华
网站建设 2026/4/23 13:04:02

合规挖漏洞能拿多少奖金?一年挖洞 300 多个,收入直接超百万

挖洞能力是白帽子的核心能力&#xff0c;通过挖洞或参加实战攻防演习获取奖金收入&#xff0c;是白帽人才获取收入的重要方式。调研显示&#xff0c;我国近四成的白帽子年均奖金收入在3000元以下&#xff0c;约六成在1万元以下。而年均奖金超过10万元的白帽子约占17.0%&#xf…

作者头像 李华