【监控】【Nginx】使用 Prometheus + Grafana 监控 Nginx

目录

  • [一、什么是 Prometheus 和 Grafana?](#一、什么是 Prometheus 和 Grafana?)
  • [二 、准备工作](#二 、准备工作)
  • [步骤 1:安装 Prometheus](#步骤 1:安装 Prometheus)
    • [1. 下载并解压 Prometheus](#1. 下载并解压 Prometheus)
    • [2. 编辑 Prometheus 配置(prometheus.yml)](#2. 编辑 Prometheus 配置(prometheus.yml))
    • [3. 启动 Prometheus](#3. 启动 Prometheus)
  • [步骤 2:安装 Grafana](#步骤 2:安装 Grafana)
    • [1. 安装 Grafana](#1. 安装 Grafana)
    • [2. 启动 Grafana](#2. 启动 Grafana)
    • [3. 访问 Grafana](#3. 访问 Grafana)
  • [步骤 3:检查 Nginx 配置与资源瓶颈](#步骤 3:检查 Nginx 配置与资源瓶颈)
    • [1. 检查配置](#1. 检查配置)
    • [2. 查看 CPU 和内存使用情况](#2. 查看 CPU 和内存使用情况)
    • [3. 调整 Nginx 配置](#3. 调整 Nginx 配置)
    • [4. 重启 Nginx](#4. 重启 Nginx)
  • [步骤 4:在 Grafana 中配置数据源](#步骤 4:在 Grafana 中配置数据源)
    • [1. 添加数据源](#1. 添加数据源)
    • [2. 创建仪表板](#2. 创建仪表板)
  • 结论

在现代应用程序中,监控是确保服务高可用性和性能的关键。本文将详细介绍如何使用 Prometheus 和 Grafana 监控 Nginx,并包含配置、运行和可视化的详细步骤。

一、什么是 Prometheus 和 Grafana?

  • Prometheus:一个开源的监控系统和时间序列数据库,具有强大的数据收集和查询能力。它通过 HTTP 爬虫从目标系统抓取指标数据。
  • Grafana:一个开源的分析和监控平台,支持多种数据源(包括 Prometheus),可以通过丰富的图表和仪表板展示数据。

二 、准备工作

确保已安装 Nginx,Prometheus 和 Grafana。下面的步骤将指导你完成配置和监控的全过程。

步骤 1:安装 Prometheus

首先,我们需要安装 Prometheus。

1. 下载并解压 Prometheus

在终端中执行以下命令:

bash 复制代码
wget https://github.com/prometheus/prometheus/releases/download/v2.30.3/prometheus-2.30.3.linux-amd64.tar.gz
tar -xvf prometheus-2.30.3.linux-amd64.tar.gz
cd prometheus-2.30.3.linux-amd64

2. 编辑 Prometheus 配置(prometheus.yml)

打开 prometheus.yml 文件,添加 Nginx 的监控配置:

yaml 复制代码
scrape_configs:
  - job_name: 'nginx'
    static_configs:
      - targets: ['localhost:8080']  # 确保 Nginx 指标暴露在此端口

3. 启动 Prometheus

在 Prometheus 目录中,使用以下命令启动:

bash 复制代码
./prometheus --config.file=prometheus.yml

步骤 2:安装 Grafana

接下来,我们安装 Grafana 来可视化监控数据。

1. 安装 Grafana

使用以下命令安装 Grafana:

bash 复制代码
sudo apt-get install -y grafana

2. 启动 Grafana

启动 Grafana 服务:

bash 复制代码
sudo systemctl start grafana-server

3. 访问 Grafana

在浏览器中输入 http://localhost:3000,默认用户名和密码为 admin/admin。第一次登录后,系统会提示你更改密码。

步骤 3:检查 Nginx 配置与资源瓶颈

在开始监控之前,我们需要确保 Nginx 的配置正确,并查看系统的资源使用情况。

1. 检查配置

使用以下命令检查 Nginx 配置是否正确:

bash 复制代码
nginx -t

2. 查看 CPU 和内存使用情况

可以使用 top 命令来实时监控系统资源:

bash 复制代码
top

3. 调整 Nginx 配置

如果需要,可以在 nginx.conf 文件中调整以下配置,以优化性能:

nginx 复制代码
worker_processes auto;  # 自动根据 CPU 核心数设置
worker_connections 1024; # 每个 worker 允许的最大连接数

4. 重启 Nginx

重启 Nginx 以应用配置更改:

bash 复制代码
sudo systemctl restart nginx

步骤 4:在 Grafana 中配置数据源

现在我们可以将 Prometheus 添加为数据源到 Grafana。

1. 添加数据源

  1. 登录到 Grafana。
  2. 点击左侧菜单中的"设置"图标,然后选择"数据源"。
  3. 点击"添加数据源"按钮。
  4. 选择 Prometheus。
  5. 在 URL 字段中输入 http://localhost:9090(默认情况下,Prometheus 运行在 9090 端口)。
  6. 点击"保存并测试"以确认连接成功。

2. 创建仪表板

  1. 点击左侧菜单中的"仪表板"图标,然后选择"新建仪表板"。
  2. 点击"添加图表",然后选择"数据源"为刚刚添加的 Prometheus。
  3. 在查询框中输入指标,例如 nginx_http_requests_total 来查看总请求数。
  4. 自定义图表样式,保存仪表板。

结论

通过以上步骤,你可以成功地使用 Prometheus 和 Grafana 监控 Nginx。这种监控解决方案不仅可以帮助你及时发现性能瓶颈,还能为应用程序的可用性提供保障。随着需求的变化,可以进一步扩展监控范围,涵盖更多的指标和服务。


相关推荐
紫璨月29 分钟前
nginx反向代理的bug
运维·nginx·bug
就叫飞六吧9 天前
基于keepalived、vip实现高可用nginx (centos)
python·nginx·centos
小生云木9 天前
Linux离线编译安装nginx
linux·运维·nginx
Cat God 00710 天前
项目上线(若依前后分离版)
java·nginx
婷儿z10 天前
LVS负载均衡群集:Nginx+Tomcat负载均衡群集
nginx·负载均衡·lvs
愿做无知一猿10 天前
【Docker】docker-compose中的nginx为何突然访问不到服务了?
nginx·docker·容器
当归102410 天前
Nginx与Tomcat:谁更适合你的服务器?
服务器·nginx·tomcat
yuren_xia10 天前
Nginx反向代理解决跨域问题详解
运维·nginx
骆驼Lara10 天前
前端跨域解决方案(6):Nginx
前端·javascript·nginx
铃木隼.10 天前
nginx代理与tomcat动静分离
运维·nginx·tomcat