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

超级实用,解密云原生监控技术,使用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博客
💕 全力以赴,持续学习,不负如来不负卿,喜欢的话记得点赞收藏哦


http://www.kler.cn/a/2713.html

相关文章:

  • 【JavaEE】 多线程的风险-线程安全
  • 《程序员成长历程的四个阶段》
  • 关于中级开发工程师常问的面试题
  • CSDN 第三十九期竞赛题解
  • 如何做好数字化知识管理?
  • Linux内核IO基础知识与概念
  • python中pandas模块数据处理小案例
  • Linux内核六大进程通信机制原理
  • 自己动手做chatGPT:向量的概念和相关操作
  • 7个最受瞩目的 Python 库,提升你的开发效率
  • 【Mysql系列】——详细剖析数据库“索引”【上篇】
  • 【排序算法】
  • Tomcat And Servlet (1)
  • 构造函数为什么不能为虚函数?析构函数为什么要为虚函数?
  • Linux内核进程管理几种CPU调度策略
  • 全网最完整,接口测试总结彻底打通接口自动化大门,看这篇就够了......
  • MyBatisPlus+SpringBoot实现乐观锁功能
  • 智能火焰与烟雾检测系统(Python+YOLOv5深度学习模型+清新界面)
  • 2023年江苏省职业院校技能大赛中职网络安全赛项试卷-教师组任务书
  • Spark Streaming DStream的操作