当前位置: 首页 > news >正文

使用dockers-compose搭建开源监控和可视化工具

简介
Prometheus 和 Grafana 是两个常用的开源监控和可视化工具。
Prometheus 是一个用于存储和查询时间序列数据的系统。它提供了用于监控和报警的数据收集、存储、查询和图形化展示能力。Prometheus 使用拉模型(pull model),通过 HTTP 协议定期从被监控的目标上获取指标数据。它支持多种方式的指标收集,包括通过各种客户端库、Prometheus Exporter、以及集成其他框架和服务等。
Grafana 是一个功能强大的数据可视化和监控仪表盘工具。它可以连接到多种数据源,包括 Prometheus、InfluxDB、Graphite 等,将收集到的数据转化为易于理解和美观的图表和仪表盘展示。Grafana 支持丰富的图表类型、灵活的自定义选项和权限控制,使用户可以根据需求创建自定义的监控仪表盘,并进行调整和共享。
通过结合 Prometheus 和 Grafana,可以搭建一个完整的监控和可视化系统。Prometheus负责数据的收集和存储,而Grafana负责数据的展示和可视化。通过这两个工具的结合,可以轻松地监控和可视化系统的各种指标,并根据需要创建仪表盘、报表和警报规则。

安装

下面是一个完整的 docker-compose.yml 文件,包括了Prometheus、Grafana(用于可视化监控数据),并设置了基本身份验证和日志轮转

sudo su #进入root用户
mkdir test #创建一个存储yml文件的目录
cd test
vim docker-compose.yml
version: '3'services:prometheus:image: prom/prometheuscontainer_name: prometheusrestart: alwaysports:- "9090:9090"volumes:- prometheus_data:/prometheus- ./prometheus:/etc/prometheusenvironment:- PROMETHEUS_STORAGE_TSDB_RETENTION_TIME=30dlogging:driver: "json-file"options:max-size: "200m"max-file: "10"grafana:image: grafana/grafanacontainer_name: grafanarestart: alwaysports:- "3000:3000"environment:- GF_SECURITY_ADMIN_PASSWORD=your_grafana_passworddepends_on:- prometheusvolumes:prometheus_data:

替换 your_grafana_password 为你设置的 Grafana 管理员密码。此配置中包括了Prometheus和Grafana服务,通过Docker Compose来定义和运行。
通过运行以下命令启动服务

docker-compose up -d

访问Prometheus的Web界面:http://localhost:9090
访问Grafana的Web界面:http://localhost:3000 (使用管理员用户名 admin 和你设置的密码登录)
这是一个基本的示例,可以根据实际需求进行更详细的配置。确保在生产环境中采取适当的安全措施,例如启用HTTPS等。

脚本释义

Prometheus服务:
image: prom/prometheus: 使用的Prometheus官方镜像。
container_name: prometheus: 指定Prometheus容器的名称为 “prometheus”。
restart: always: 当容器停止时,总是重新启动它。
ports: - “9090:9090”: 将主机的9090端口映射到Prometheus容器的9090端口,用于访问Prometheus的Web界面。
volumes: - prometheus_data:/prometheus - ./prometheus:/etc/prometheus: 挂载两个卷,一个用于持久化Prometheus数据,另一个用于存储Prometheus配置文件。
environment: - PROMETHEUS_STORAGE_TSDB_RETENTION_TIME=30d: 设置Prometheus存储的时间保留期为30天。
logging: driver: “json-file” options: max-size: “200m” max-file: “10”: 配置Prometheus容器的日志驱动为 “json-file”,并设置日志文件的大小和数量。
Grafana服务:
image: grafana/grafana: 使用的Grafana官方镜像。
container_name: grafana: 指定Grafana容器的名称为 “grafana”。
restart: always: 当容器停止时,总是重新启动它。
ports: - “3000:3000”: 将主机的3000端口映射到Grafana容器的3000端口,用于访问Grafana的Web界面。
environment: - GF_SECURITY_ADMIN_PASSWORD=your_grafana_password: 设置Grafana管理员密码。
depends_on: - prometheus: 指定Grafana容器依赖于Prometheus容器,在Prometheus容器启动后再启动Grafana容器。
共享卷:
volumes: - prometheus_data:: 定义了名为 “prometheus_data” 的共享卷,用于持久化Prometheus数据。
这个 docker-compose.yml 文件定义了两个服务:Prometheus和Grafana,它们都可以通过Docker Compose一键启动。Prometheus用于监控和收集指标数据,而Grafana用于可视化这些数据。可以根据实际需求对Prometheus的配置文件进行定制,并进一步配置Grafana以显示监控仪表板。
运行界面
在这里插入图片描述
#########################################################################################################################################################在这里插入图片描述

http://www.lryc.cn/news/289960.html

相关文章:

  • 浏览器——HTTP缓存机制与webpack打包优化
  • STM32duino舵机控制-2
  • 【知识---如何创建 GitHub 个人访问令牌】
  • GBASE南大通用分享-ConnectionTimeout 属性
  • ChatGPT 全域调教高手:成为人工智能交流专家
  • 5.Hive表修改Location,一次讲明白
  • 基于springboot校园台球厅人员与设备管理系统源码和论文
  • MySQL(下)
  • 如何搭建开源笔记Joplin服务并实现远程访问本地数据
  • 免费分享一套微信小程序外卖跑腿点餐(订餐)系统(uni-app+SpringBoot后端+Vue管理端技术实现) ,帅呆了~~
  • 后端学习:数据库MySQL学习
  • 2024最新版IntelliJ IDEA安装使用指南
  • 消息中间件及java线程池
  • 关于axios给后端发送数据的问题
  • web前端之ES6的实用深度解构赋值方法、复杂的解构赋值
  • uni-app 接口封装,token过期,自动获取最新的token
  • AWS免费套餐——云存储S3详解
  • 2723. 两个 Promise 对象相加
  • 【方法论】费曼学习方法
  • Transformer模型 | Pytorch实现Transformer模型进行时间序列预测
  • Git推送大量内容导致http 413错误
  • pytest框架的基本使用
  • C++STL之map、set的使用和模拟实现
  • 100天精通鸿蒙从入门到跳槽——第18天:ArkTS组件状态管理装饰器
  • 【前端】防抖
  • python对图片或文件的操作
  • 架构篇19:单服务器高性能模式-Reactor与Proactor
  • PyInstaller 将 Python 程序生成可直接运行的程序
  • 专有钉钉开发记录,及问题总结
  • Java Swing桌面项目打包成可执行jar