【监控】【Nginx】使用 Docker 部署 Prometheus + Grafana 监控 Nginx

news/2024/9/23 18:08:30/

在现代应用程序中,监控是确保服务高可用性和性能的关键。本文将详细介绍如何使用 Docker 部署 Prometheus 和 Grafana,以监控 Nginx。我们将分步骤讲解每个环节,以确保你能够顺利完成整个过程。

准备工作

在开始之前,请确保你的系统上已安装 Docker 和 Docker Compose。这两个工具将帮助我们轻松创建和管理容器化的应用环境。

步骤 1:创建项目目录

首先,我们需要创建一个新的目录来存放所有配置文件。这有助于保持项目的结构清晰。

mkdir nginx-monitoring
cd nginx-monitoring

步骤 2:创建 Prometheus 配置文件

接下来,创建一个名为 prometheus.yml 的文件,这是 Prometheus 的配置文件,定义了监控的目标和抓取间隔。

global:scrape_interval: 15s  # 设置全局抓取间隔为15秒scrape_configs:- job_name: 'nginx'  # 监控任务的名称static_configs:- targets: ['nginx:80']  # 指定 Nginx 服务的名称和端口

解释

  • global:定义全局配置,如抓取间隔。
  • scrape_configs:配置要监控的服务,这里我们将 Nginx 的指标作为目标。

步骤 3:创建 Docker Compose 文件

然后,创建一个 docker-compose.yml 文件,定义我们需要的服务,包括 Nginx、Prometheus 和 Grafana。

version: '3.7'  # Docker Compose 文件版本services:nginx:image: nginx:latest  # 使用最新的 Nginx 镜像ports:- "8080:80"  # 将宿主机的8080端口映射到容器的80端口volumes:- ./nginx.conf:/etc/nginx/nginx.conf  # 自定义 Nginx 配置文件prometheus:image: prom/prometheus  # 使用 Prometheus 镜像ports:- "9090:9090"  # 将宿主机的9090端口映射到容器的9090端口volumes:- ./prometheus.yml:/etc/prometheus/prometheus.yml  # 挂载 Prometheus 配置文件command:- '--config.file=/etc/prometheus/prometheus.yml'  # 指定配置文件位置grafana:image: grafana/grafana  # 使用 Grafana 镜像ports:- "3000:3000"  # 将宿主机的3000端口映射到容器的3000端口

解释

  • services:定义我们要运行的服务。
  • image:指定要使用的 Docker 镜像。
  • ports:配置端口映射,使得我们可以从宿主机访问容器中的服务。
  • volumes:挂载配置文件到容器,以便于管理。

步骤 4:创建 Nginx 配置文件

在项目目录中创建一个 nginx.conf 文件,以设置 Nginx 的指标导出。

nginx">worker_processes 1;  # 设置工作进程数events { worker_connections 1024;  # 最大连接数
}http {server {listen 80;  # Nginx 监听80端口location / {root   /usr/share/nginx/html;  # 静态文件根目录index  index.html index.htm;  # 默认首页}location /metrics {stub_status on;  # 启用 stub_status 模块以导出指标}}
}

解释

  • worker_processesevents:基本的 Nginx 配置。
  • location /metrics:指定一个路径用于导出 Nginx 的指标。

步骤 5:启动 Docker 容器

在项目目录中运行以下命令以启动服务:

docker-compose up -d  # 后台运行 Docker 容器

解释

  • -d 选项使得容器在后台运行,便于继续在终端中执行其他命令。

步骤 6:访问 Grafana 和 Prometheus

服务启动后,我们可以访问 Grafana 和 Prometheus。

  • Grafana:在浏览器中访问 http://localhost:3000。默认的用户名和密码都是 admin/admin,首次登录时系统会提示你更改密码。
  • Prometheus:在浏览器中访问 http://localhost:9090,可以查看抓取的指标。

步骤 7:配置 Grafana 数据源

  1. 登录到 Grafana。
  2. 点击左侧菜单中的“设置”图标,然后选择“数据源”。
  3. 点击“添加数据源”按钮,选择 Prometheus。
  4. 在 URL 字段中输入 http://prometheus:9090(这是 Docker 内部网络中使用的服务名称)。
  5. 点击“保存并测试”以确认连接成功。

解释

这一步骤确保 Grafana 可以正确连接到 Prometheus,获取监控数据。

步骤 8:创建仪表板

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

解释

通过创建仪表板,你可以可视化 Nginx 的性能数据,帮助你更好地理解服务的运行状态。

结论

通过 Docker 部署 Prometheus 和 Grafana,你可以方便地监控 Nginx。这一解决方案不仅简单易用,还能根据需要灵活扩展。希望这篇博客对你有所帮助,助你成功构建一个强大的监控系统!



http://www.ppmy.cn/news/1529436.html

相关文章

Redis详细解析

Redis 什么是Redis?关系型与非关系型数据库Redis可以做什么Redis入门安装在Windows系统上安装在Linux系统上安装 Redis在Linux系统上启动运行如何设置redis-server后台运行与关闭如何设置redis客户端登录时需要验证密码**设置允许远程连接redis服务**Redis数据类型Redis常用命…

帝可得项目总结

业务需求 在区域列表查询中,需要显示每个区域的点位数 (1)同步存储:在区域表中有点位数的字段(冗余字段6.),当点位发生变化时,同步区域表中的点位数。 优点:由于是单表查询操作,查询列表效率最高。 缺点…

RHEL7(RedHat红帽)软件安装教程

目录 1、下载RHEL7镜像 2、安装RedHat7 注:如果以下教程不想看,可以远程控制安装V:OYH-Cx330 【风险告知】 本人及本篇博文不为任何人及任何行为的任何风险承担责任,图解仅供参考,请悉知!本次安装图解是在一个全新的演…

【人工智能学习之卷积神经网络发展简述】

【人工智能学习之卷积神经网络发展简述】 早期探索(1960s-1980s)初步发展(1990s-2000s)快速增长(2010s)当前进展(2010s末-2020s)未来趋势总结 卷积神经网络(Convolutiona…

[论文笔记]MRRNET

这是一篇河大的论文 感觉跟SANET很像 摘要 摘要:随着物联网(IoT)的大规模部署,道路场景中实时感知和环境理解的需求变得越来越迫切。 同时,语义分割作为像素级场景解析得到了广泛的研究。 然而,资源有限…

解决 TortoiseGitPlink Fatal Error:深入解析

解决 TortoiseGitPlink Fatal Error:深入解析 在 Windows 平台上,开发者使用 Git 和 TortoiseGit 进行版本控制时,有时会遇到 TortoiseGitPlink Fatal Error。该错误通常是在推送/拉取代码时,客户端未能提供正确的 SSH 密钥。 1…

11年408考研真题解析-计算机网络

第一题: 解析:网络层虚电路服务和数据报服务 传输服务只有:有连接可靠和无连接不可靠两种,直接排除BC。 网络层指的是IP协议,由图二可知:运输层,网际层,网络接口层唯一有连接可靠的协…

开放标准如何破解企业数字化与可持续发展的困境:The Open Group引领生态系统架构创新

应对数字化与可持续发展的双重挑战,开放标准是关键 在当今快速变化的商业环境中,企业不仅需要通过数字化转型提升竞争力,还面临日益严格的可持续发展要求。开放标准正在成为企业破解这一双重挑战的核心工具。The Open Group 2024生态系统架构…