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

超级实用,解密云原生监控技术,使用prometheus轻松搞定redis监控

前言

大家好,我是沐风晓月,本文收录于《 prometheus监控系列》 ,截止目前prometheus专栏已经更新到第8篇文章。

本文中的是prometheus已经安装好,如果你还未安装,可以参考

  • prometheus安装及使用入门

若你想监控其他服务可以参考:

  • 监控远程主机: 云原生系列之使用 prometheus监控远程主机实战
  • 监控MySQL: 云原生系列之使用 prometheus监控MySQL实战
  • 监控nginx : 云原生系列之使用prometheus监控nginx
  • 监控tomcat :
    【云原生】prometheus结合jmx exporter 的http server模式采集tomcat监控实战
    【云原生】prometheus结合jmx exporter 的java agent模式采集tomcat监控实战

如果你想实现更炫酷的可视化效果:

  • 【云原生】promehtheus整合grafana实现可视化监控实战

想学习更多prometheus内容,可以关注沐风晓月 的专栏:prometheus监控系列

文章目录

  • 前言
  • 一. 实验环境
  • 二. redis_exporter简介
    • 2.1 什么是redis_exporter呢?
    • 2.2 在哪里可以下载redis_exporter呢?
  • 三. 安装redis
    • 3.1 安装redis
    • 3.2 修改redis的配置文件
    • 3.3 启动redis
    • 3.4 查看redis启动状态
  • 四. 安装redis_exporter
    • 4.1 下载redis_exporter
    • 4.2 解压安装包并创建软连接
    • 4.3 查看redis_exporter的帮助
    • 4.4 添加redis_exporter的启动文件
    • 4.5 创建运行redis_exporter的用户
    • 4.6 修改redis_exporter目录所属
    • 4.7 启动redis_exporter并设置开机启动
    • 4.8 查看redis_exporter启动状态
    • 4.9 查看redis_exporter监控的数据
  • 五. 配置prometheus采集redis_exporter数据
    • 5.1 修改prometheus配置文件
    • 5.2 检查prometheus配置文件的语法
    • 5.3 让prometheus重新读取配置文件
  • 六. 查看prometheus监控的数据
    • 6.1 查看prometheus监控的目标
    • 6.2 查看prometheus是否采集到redis_exporer暴露的数据
  • 七. 导入grafana模板
    • 7.1 导入模板
    • 7.2 查看结果
  • 总结

一. 实验环境

本次实验环境见下表

操作系统服务器IPhostname
centos7.910.0.0.7mufengrow7

如何查看相应的参数

二. redis_exporter简介

2.1 什么是redis_exporter呢?

我们都知道redis是由C语言编写的一款高性能的NoSQL,无论在生产,测试,还是在开发的环境都可以用的上。所以对redis的监控就由为重要,而redis_exporter就是一个对redis实行实时监控的一款开源监控软件。

redis_exporter是由go语言开发的软件,并且prometheus官方推荐的一个第三方采集redis数据的exporter。

该exporter支持多个版本的redis,如:2.x,3.x,4.x,5.x,6.x和7.x。也就是说现在主流版本的redis,redis_exporter都支持。

2.2 在哪里可以下载redis_exporter呢?

在我们进入到prometheus的下载页面时,发现根本没有“redis_exporter”的下载连接。

既然没有提供redis_rxporter的下载链接,为什么上面会说redis_exproter是prometheus官方推荐用来监控的exporer呢?

其实在官方的下载页面里,第二段话里说明了prometheus官方推荐的的exproter。我们可以点击Exporters and integrations链接,进入该页面,就可以找到redis_exporter的下载页面。

点击进入页面,在“Databases”模块里找到redis_exporter,点击连接就可以进入redis_的github页面。

为了方便大家,这里沐风晓月直接把redis_exporter的github地址链接给贴出来,大家可以点击“redis_exporter”的链接复制下面的链接进行访问

https://prometheus.io/docs/instrumenting/exporters/

三. 安装redis

本次实验安装的redis的版本是3.2.12,通知也是centos7仓库的默认版本

3.1 安装redis

使用yum命令直接安装redis

[root@mufengrow7 ~]# yum install -y redis

看见Installed就说明redis安装完成

3.2 修改redis的配置文件

修改配置文件主要是修改redis的监听地址(redis默认的监听地址是127.0.0.1)和给redis添加密码(redis默认没有密码)。

[root@mufengrow7 ~]# vim /etc/redis.conf
#修改以下内容
bind 127.0.0.1
改为
bind 0.0.0.0 #修改监听地址

# requirepass foobared
修改为
requirepass 123456 #给redis添加密码

3.3 启动redis

使用systemctl命令启动redis

[root@mufengrow7 ~]# systemctl restart redis

3.4 查看redis启动状态

使用psss命令查看redis的进程和监听地址

#查看进程
[root@mufengrow7 ~]# ps -ef | grep redis | grep -v grep
redis      1813      1  0 15:48 ?        00:00:00 /usr/bin/redis-server 0.0.0.0:6379
#查看监听地址
[root@mufengrow7 ~]# ss -tnl
State      Recv-Q Send-Q                                  Local Address:Port                                                 Peer Address:Port              
LISTEN     0      128                                                 *:6379                                                            *:*                  
LISTEN     0      128                                                 *:22                                                              *:*                  
LISTEN     0      128                                              [::]:9090                                                         [::]:*                  
LISTEN     0      128                                              [::]:22                                                           [::]:*

四. 安装redis_exporter

4.1 下载redis_exporter

进入到redis_exporter的github页面,点击右方的“Releases”,就可以选择redis_exporterr的版本进行下载。

我们下载最新版本的redis_exporter

#创建安装目录
[root@mufengrow7 ~]# mkdir -p /apps
#进入安装目录
[root@mufengrow7 ~]# cd /apps/
#使用“wget”命令进行下载
[root@mufengrow7 apps]# wget https://github.com/oliver006/redis_exporter/releases/download/v1.48.0/redis_exporter-v1.48.0.linux-amd64.tar.gz

4.2 解压安装包并创建软连接

这里给redis_exporter创建软连接是方便以后对redis_exporter进行升级换代。如果嫌麻烦这一步可以忽略。

[root@mufengrow7 apps]# tar zxf redis_exporter-v1.48.0.linux-amd64.tar.gz 
[root@mufengrow7 apps]# ln -sv /apps/redis_exporter-v1.48.0.linux-amd64 /apps/redis_exporter
‘/apps/redis_exporter’ -> ‘/apps/redis_exporter-v1.48.0.linux-amd64’

4.3 查看redis_exporter的帮助

[root@mufengrow7 apps]# cd redis_exporter
[root@mufengrow7 redis_exporter]# ./redis_exporter --help

从上面查看帮助的结果可以看到redis_exporter的选项是非常多,在这里,沐风晓月挑选了几个常用的选项来给大家说明。

参数说明
-web.listen-address设置redis_exporter监听端口,默认是“:9121”
-web.telemetry-path设置暴露指标的路径,默认是“/metrics”
-redis.addrredis的监听地址,默认是“redis://localhost:6379”
-redis.passwordredis密码,默认是无密码
-redis-only-metrics是否要输出运行时指标

4.4 添加redis_exporter的启动文件

[root@mufengrow7 redis_exporter]# vim /usr/lib/systemd/system/redis_exporter.service
[Unit]
Description=Prometheus exporter for machine metrics
Documentation=https://github.com/prometheus/node_exporter
After=network.target

[Service]
ExecStart=/apps/redis_exporter/redis_exporter -redis.password 123456
ExecReload=/bin/kill -HUP $MAINPID
User=prometheus
Restart=always
TimeoutStopSec=20s
SendSIGKILL=no

[Install]
WantedBy=multi-user.target

4.5 创建运行redis_exporter的用户

[root@mufengrow7 redis_exporter]# useradd -M -r -s /sbin/nologin prometheus

代码注释:

-M:不创建登录的家目录

-r:建立系统用户

-s:指定登录的shell类型

4.6 修改redis_exporter目录所属

[root@mufengrow7 redis_exporter]# chown -R prometheus.prometheus /apps/redis_exporter-v1.48.0.linux-amd64

4.7 启动redis_exporter并设置开机启动

#读取service文件
[root@mufengrow7 redis_exporter]# systemctl daemon-reload
#启动redis_exporter
[root@mufengrow7 redis_exporter]# systemctl start redis_exporter.service 
#设置redis_exporter开机启动
[root@mufengrow7 redis_exporter]# systemctl enable redis_exporter.service 
Created symlink from /etc/systemd/system/multi-user.target.wants/redis_exporter.service to /usr/lib/systemd/system/redis_exporter.service.

4.8 查看redis_exporter启动状态

[root@mufengrow7 redis_exporter]# ps -ef | grep redis_exporter | grep -v grep
prometh+   1972      1  0 16:52 ?        00:00:00 /apps/redis_exporter/redis_exporter -redis.password 123456
[root@mufengrow7 redis_exporter]# ss -tnl
State      Recv-Q Send-Q                                  Local Address:Port                                                 Peer Address:Port              
LISTEN     0      128                                                 *:6379                                                            *:*                  
LISTEN     0      128                                                 *:22                                                              *:*                  
LISTEN     0      128                                              [::]:9121                                                         [::]:*                  
LISTEN     0      128                                              [::]:9090                                                         [::]:*                  

4.9 查看redis_exporter监控的数据

浏览器访问:

10.0.0.7:9121/metrics

下面为redis_exporter采集到的部分数据

五. 配置prometheus采集redis_exporter数据

5.1 修改prometheus配置文件

修改的方式如图:

5.2 检查prometheus配置文件的语法

检查结果出现“SUCCESS”证明语法没问题,可以让prometheus重新读取文件

[root@mufengrow7 prometheus]# ./promtool check config prometheus.yml 
Checking prometheus.yml
 SUCCESS: prometheus.yml is valid prometheus config file syntax

5.3 让prometheus重新读取配置文件

[root@mufengrow7 prometheus]# systemctl restart  prometheus.service

六. 查看prometheus监控的数据

6.1 查看prometheus监控的目标

我们到prometheus的网页端的Targets查看prometheus是否能能连接上redis_exporter。

6.2 查看prometheus是否采集到redis_exporer暴露的数据

我们到prometheus网页端的Graph,搜索redis_exporter的监控项,查看prometheus是否采集到数据。

通过下面的查询,我们确定了prometheus已经有采集到redis_exporter的数据。

  • 查看“redis_instance_info”数据

  • 查看“redis_uptime_in_seconds”

  • 查看“redis_db_keys”

七. 导入grafana模板

本文中的grafana已经安装好了,如果你还未安装,可以参考文章:promehtheus整合grafana实现可视化监控实战

7.1 导入模板

grafana推荐模板:763

以编号763为例:

  • 输入模板编号,点击右方的Load

  • 选择prometheus的数据源,点击Import导入模板

7.2 查看结果

以下是编号为“763”模板的结果,如果目标有什么问题可以自行修改

总结

prometheus的专栏持续更新中,欢迎留言跟我一起讨论,点赞收藏吧

💕 好啦,这就是今天要分享给大家的全部内容了,我们下期再见!
💕 博客主页:mufeng.blog.csdn.net
💕 本文由沐风晓月原创,首发于CSDN博客
💕 全力以赴,持续学习,不负如来不负卿,喜欢的话记得点赞收藏哦

相关文章:

  • MyBatis高频面试题
  • C++中那些你不知道的未定义行为
  • 电容在微分、积分电路中的本质以及应用
  • 【系统学习】环境土壤物理模型HYDRUS1D/2D/3D
  • 解决Xshell无法连接Kali Linux 2020.1(2019.3)版本
  • python 基础系列篇:四、编写两个简单的小游戏(猜数字及2048)
  • async与await异步编程
  • MyBatisPlus+SpringBoot实现乐观锁功能
  • 【Vue全家桶】带你全面了解通过Vue CLI初始化Vue项目
  • CSS 属性计算过程
  • 一文了解Jackson注解@JsonFormat及失效解决
  • 全自动托盘四向穿梭车|拥有输送系统提升机AGV的托盘四向穿梭车立体库的软硬件配置系统
  • “你要多弄弄算法”
  • 【Android -- 开发工具】Xshell 6 安装和使用教程
  • Tomcat And Servlet (1)
  • 「面试题」如何实现一个圣杯布局?
  • Android单元测试 - 几个重要问题
  • Android交互
  • Apache的基本使用
  • HTTP请求重发
  • JavaScript对象详解
  • JavaScript类型识别
  • JS基础篇--通过JS生成由字母与数字组合的随机字符串
  • mysql常用命令汇总
  • windows下如何用phpstorm同步测试服务器
  • 阿里云爬虫风险管理产品商业化,为云端流量保驾护航
  • 码农张的Bug人生 - 初来乍到
  • 三栏布局总结
  • 新版博客前端前瞻
  • 学习HTTP相关知识笔记
  • 职业生涯 一个六年开发经验的女程序员的心声。
  • shell使用lftp连接ftp和sftp,并可以指定私钥
  • ​猴子吃桃问题:每天都吃了前一天剩下的一半多一个。
  • # 20155222 2016-2017-2 《Java程序设计》第5周学习总结
  • (3)选择元素——(14)接触DOM元素(Accessing DOM elements)
  • (AtCoder Beginner Contest 340) -- F - S = 1 -- 题解
  • (HAL库版)freeRTOS移植STMF103
  • (javascript)再说document.body.scrollTop的使用问题
  • (MonoGame从入门到放弃-1) MonoGame环境搭建
  • (原)Matlab的svmtrain和svmclassify
  • (原創) 未来三学期想要修的课 (日記)
  • (转)C语言家族扩展收藏 (转)C语言家族扩展
  • (转载)PyTorch代码规范最佳实践和样式指南
  • ./indexer: error while loading shared libraries: libmysqlclient.so.18: cannot open shared object fil
  • .NET CLR基本术语
  • .Net Remoting常用部署结构
  • .Net 应用中使用dot trace进行性能诊断
  • .net6使用Sejil可视化日志
  • .NetCore部署微服务(二)
  • .Net下使用 Geb.Video.FFMPEG 操作视频文件
  • .php文件都打不开,打不开php文件怎么办
  • @Autowired @Resource @Qualifier的区别
  • @RequestParam详解
  • [2016.7.test1] T2 偷天换日 [codevs 1163 访问艺术馆(类似)]
  • [android] 看博客学习hashCode()和equals()