热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

redis端口_使用Prometheus和Grafana构建Redis实时监控平台

Redis作为缓存系统,在整个后端体系中是较为重要的一环,需要实时监控运行状态。现在有各种各样的工具都可以对Redis进行监控,例如&#x

afdf6d38a241b53e729f98c9214d9505.png

Redis作为缓存系统,在整个后端体系中是较为重要的一环,需要实时监控运行状态。现在有各种各样的工具都可以对Redis进行监控,例如:redis-stat、RedisLive等,在使用过各种各样的监控工具后,个人感觉redis_exporter较为好用,配合Prometheus+Grafana,不仅监控灵活、展现直观还可以进行自行封装来获取各种特别关注的数据指标。今天就和大家分享redis-exporter+Grafana+Prometheus构建Redis实时监控。

4e6a60fe2e1df3ce4fff3c4ec433646e.png

由于在物理机中搭建redis-exporter+Grafana+Prometheus较为繁琐,下面直接利用Docker来搭建这一套监控体系作为实例。不熟悉Docker也不要紧,这里只是熟悉监控流程。搭建准备

0e82d2900a91713420607481067d0598.png

启动Redis实例首先准备两个Redis作为监控实例,打开Docker Hub官网搜索Redis,会有启动Redis实例的命令提示,这里按照最简单的方法启动两个Redis(后台运行的方式按照最新的redis镜像启动两个名为redis1/redis2的容器实例):网站地址:https://hub.docker.com/_/redis

➜ ~ docker run -d --name redis1 redis
➜ ~ docker run -d --name redis2 redis

Redis实例准备好了以后我们需要查看并记录容器所属的IP地址,以便redis_exporter来监控。

➜ ~ docker inspect redis1|grep IPAddress 172.17.0.5
➜ ~ docker inspect redis2|grep IPAddress 172.17.0.6

Grafana端口映射准备监控数据展示工具Grafana。

➜ ~ docker run -d --name=grafana -p 3000:3000 grafana

这里由于需要在外部访问Grafana图形展示工作,所以做个端口映射,将物理机的3000端口和容器Grafana的3000端口关联起来。配置redis_exporter准备数据采集工具redis_exporter,这里默认监听端口9121。

➜ ~ docker run -d --name redis_exporter -p 9121:9121 oliver006/redis_exporter --redis.addr=172.17.0.5:6379,172.17.0.6:6379

--redis_addr为redis_exporter指定参数,可以指定多个监控的Redis地址,以逗号分隔,这里填入之前两个Redis的地址。准备数据抓取工具Prometheus这里需要提前准备Prometheus配置文件,抓取redis_exporter收集到的数据,最简单的配置如下图所示:

➜ ~ docker run -d --name prome -p 9090:9090 -v /tmp/prometheus.yml:/tmp/prometheus.yml quay.io/prometheus/prometheus --config.file=/tmp/prometheus.yml

这里根据普罗米修斯镜像创建一个prome的容器,同时将物理机的/tmp/prometheus.yml文件挂载到容器的/tmp下,将这个/tmp/prometheus.yml作为容器prome的启动配置文件。配置文件内容如下图:

dc2431154c0ab719c93dcf4484258aeb.png

这里创建了两个抓取数据的任务:
  • 监控本容器的9090端口即容器prome本身的数据

  • 监控容器redis_exporter的9121端口获取数据

前为止我们创建了五个容器,如下图所示:

d8f4e93aee40263d0cbbcd982fe2e444.png

使用Grafana做图表展示

0e82d2900a91713420607481067d0598.png

下面开始创建监控数据展示图,由于创建容器时已经将容器端口于物理机端口映射起来,我们可以直接利用127.0.0.1:port来访问容器内的服务。配置Prometheus监控数据源例如访问http://127.0.0.1:3000来访问Grafana图形展示工具,默认用户密码均为admin,登录进去以后配置grafana数据来源,Choose data source type中点击选择Prometheus。下一步配置数据源名称prometheus-redis和url地址,这里的数据源是本机里面的容器prome抓取上来的数据,所以url地址填默认选项即可。现在就可以创建监控数据展示图了,监控数据的监控是由redis_exporter这个服务决定的,我们访问http://127.0.0.1:9121/metrics时可以发现很多数据,可以理解为key-value的形式,key是数据查询维度,value是值。例如数据维度是redis_up,那么我们可以在访问http://127.0.0.1:9090执行redis_up这个数据查询指标抓取数据的值,如下图所示:

25b2424168f152475c45a294a42801cd.png

创建监控图表接下来我将利用prome抓取的数据在Grafana上创建一个监控Redis运行时间的展示图形,相关配置如下图,可以自行学习Grafana和Prometheus相关知识来配置各种各样的监控图形及告警相关内容。下图中一个简单的监控Redis启动时间的图形就构建完成了。

846c076da84c3dc8d3783774b9958d1e.png

如果嫌一个个配置监控图麻烦,也可以利用开源已有的模板来构建Redis监控图,将https://grafana.com/api/dashboards/763/revisions/1/download监控模板导入即可:

fc3c0afe6dd1cf1cc247eaf5e6fa3693.png

填入url后自动跳转到监控面板名称、数据源填写页面:

803e44c910ac4eb70b78404d41028b23.png

查看监控数据load以后现成的监控图就有了,Redis命中率、Redis数据量、Redis内存、Redis命令执行相关的监控应有尽有,可以自行修改监控指标来满足业务需求。最终监控成品如下图:

8f469a8ecada58955d2757c0df5d758b.png

Prometheus+Grafana是一套十分强大的监控工具,这里仅仅是收集了redis_exporter采集的数据监控Redis作为示例,我们还可以添加其他数据采集工具来监控更多的业务,有兴趣的小伙伴可以自行研究。文章来源:java进阶架构师,点击查看原文。DDD实战演练工作坊

0e82d2900a91713420607481067d0598.png

DDD实战演练工作坊将于2020年10月17日在北京开课。DDD全过程工作坊将以事件风暴为纵贯线,以领域场景为横切面,驱动从战略设计到战术设计的全生命周期的完整开发过程。内容涵盖事件风暴、限界上下文、上下文映射、角色构造型、场景驱动设计和测试驱动开发。整个工作坊围绕一个全真案例进行演练,实践具有实操价值的领域驱动设计方法。点击下方图片或者阅读原文链接查看详情。

57853135502862d2cd7020b64dca2cc1.png




推荐阅读
  • 本文探讨了Android系统中支持的图像格式及其在不同版本中的兼容性问题,重点涵盖了存储、HTTP传输、相机功能以及SparseArray的应用。文章详细分析了从Android 10 (API 29) 到Android 11 的存储规范变化,并讨论了这些变化对图像处理的影响。此外,还介绍了如何通过系统升级和代码优化来解决版本兼容性问题,以确保应用程序在不同Android版本中稳定运行。 ... [详细]
  • Node.js 配置文件管理方法详解与最佳实践
    本文详细介绍了 Node.js 中配置文件管理的方法与最佳实践,涵盖常见的配置文件格式及其优缺点,并提供了多种实用技巧和示例代码,帮助开发者高效地管理和维护项目配置,具有较高的参考价值。 ... [详细]
  • FastDFS Nginx 扩展模块的源代码解析与技术剖析
    FastDFS Nginx 扩展模块的源代码解析与技术剖析 ... [详细]
  • 在CentOS 7上部署WebRTC网关Janus
    在CentOS 7上部署WebRTC网关Janus ... [详细]
  • 在网络故障排查中,tcpdump 是一款强大的工具,尤其在 Linux 环境下。尽管开发环境中问题较少,但在测试或生产环境中,往往会遇到各种难以预料的异常情况。通过在问题发生的环境中启用 tcpdump 进行抓包,并重现问题,可以获取到宝贵的原始数据,为问题的诊断提供关键线索。本文将详细介绍如何使用 tcpdump 进行实战操作,帮助读者掌握这一技能。 ... [详细]
  • 本文深入解析了 FCEUX 源码,并详细介绍了两种制作 DEB 包的方法及其技术细节。首先,DEB 包通常由两部分组成:控制信息(位于 DEBIAN 目录)和安装内容(模拟目录)。通过解压现有的 DEB 包,可以查看其内部结构,进而理解其工作原理。具体操作包括将安装内容释放到指定目录中,以便进行进一步的修改和定制。此外,文章还探讨了如何修改现有的 DEB 包,以满足特定需求,提供了实用的步骤和技巧。 ... [详细]
  • 本文深入探讨了 hCalendar 微格式在事件与时间、地点相关活动标记中的应用。作为微格式系列文章的第四篇,前文已分别介绍了 rel 属性用于定义链接关系、XFN 微格式增强链接的人际关系描述以及 hCard 微格式对个人和组织信息的描述。本次将重点解析 hCalendar 如何通过结构化数据标记,提高事件信息的可读性和互操作性。 ... [详细]
  • Spring框架中的面向切面编程(AOP)技术详解
    面向切面编程(AOP)是Spring框架中的关键技术之一,它通过将横切关注点从业务逻辑中分离出来,实现了代码的模块化和重用。AOP的核心思想是将程序运行过程中需要多次处理的功能(如日志记录、事务管理等)封装成独立的模块,即切面,并在特定的连接点(如方法调用)动态地应用这些切面。这种方式不仅提高了代码的可维护性和可读性,还简化了业务逻辑的实现。Spring AOP利用代理机制,在不修改原有代码的基础上,实现了对目标对象的增强。 ... [详细]
  • CentOS 7环境下Jenkins的安装与前后端应用部署详解
    CentOS 7环境下Jenkins的安装与前后端应用部署详解 ... [详细]
  • 2016-2017学年《网络安全实战》第三次作业
    2016-2017学年《网络安全实战》第三次作业总结了教材中关于网络信息收集技术的内容。本章主要探讨了网络踩点、网络扫描和网络查点三个关键步骤。其中,网络踩点旨在通过公开渠道收集目标信息,为后续的安全测试奠定基础,而不涉及实际的入侵行为。 ... [详细]
  • TypeScript 实战分享:Google 工程师深度解析 TypeScript 开发经验与心得
    TypeScript 实战分享:Google 工程师深度解析 TypeScript 开发经验与心得 ... [详细]
  • 在CentOS上部署并使用FFmpeg多媒体处理工具
    最近在进行音频处理时需要用到FFmpeg,本文将详细介绍如何在CentOS系统上部署并使用这一强大的多媒体处理工具。首先,从官方网站下载FFmpeg的最新版本,然后通过Xftp工具将下载的压缩包(如ffmpeg-4.3.1.tar.xz)传输到服务器上。接下来,解压文件并按照官方文档进行编译安装。安装完成后,可以通过命令行工具验证FFmpeg是否成功安装,并开始进行多媒体文件的转换和处理。此外,文章还将介绍一些常用的FFmpeg命令和参数,帮助用户快速上手。 ... [详细]
  • Go 项目中数据库配置文件的优化与应用 ... [详细]
  • 在 CentOS 6.6 系统中搭建 MONO 和 Jexus 以支持 ASP.NET 及 MVC 应用的运行环境配置指南
    本文提供了在 CentOS 6.6 系统上配置 MONO 和 Jexus 以支持 ASP.NET 及 MVC 应用的详细步骤。首先,确保本机环境为 CentOS 6.6,并使用阿里云的 YUM 源来安装必要的软件包,包括 gcc、gcc-c++、bison、pkgconfig 和 glib2-devel。这些软件包是构建和运行 MONO 环境的基础,确保系统能够顺利支持 ASP.NET 和 MVC 应用的部署和运行。 ... [详细]
  • 在GitHub上克隆vue-element-admin项目时遇到依赖安装错误
    在 GitHub 上克隆 vue-element-admin 项目后,使用 `npm install` 安装依赖时遇到了未知的 Git 错误。具体错误信息为 `npm ERR! code 128`,提示命令执行失败。这可能是由于网络问题、Git 配置不正确或某些依赖包的仓库地址无效导致的。建议检查网络连接、更新 Git 版本并确保所有依赖项的 URL 正确无误。 ... [详细]
author-avatar
JY哥在世
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有