尽管现在阿里云腾讯云已经提供了非常方便的Redis服务,但相信大部分人和公司都有着自己搭建Redis服务器的经历,如果你是一个后台开发或者运维工程师,就常常有这样的需求,Redis运行情况如何,占用内存多少,流量有没有异常?如果能够开发一款可视化的工具,那么对我们日常的工作会有极大的帮助。今天,我们来学习下一个Redis的命令,info。只要掌握了这个命令,相信你也能够开发一款自己的Redis可视化监控工具。
Redis info命令非常的简单,只要打出info命令即可,就可以展示出非常多的内容,主要分为下面几个模块。
Server模块,主要是Redis服务器上面的服务器信息:
例如系统的版本,服务器的版本,gcc的版本等。
Client模块,主要用来展示一些客户端的信息:
包括我们常用的查看有多少个客户端连接,有多少个客户端正在阻塞等待,最大最小的输入输出buffer是多少。
通过这个监控项,我们可以很轻松的发现,Redis中是否存在大Value的数据,如果数据过大,可能会降低性能。
Memory模块,顾名思义,这是一些内存信息。
通过这个命令,你可以看到Redis的占用的内存大小,可以看到峰值数据,这是一项非常重要的监控,如果我们看到内存使用非常大,并且没有回落的趋势,可以反思下业务是否没有对可删除的数据设置过期时间等等。
Persistence模块,这个是持久化信息。
之前我们说到,Redis是可以持久化存储的,配置就在这里。常用的配置有最近一次持久化有没有成功?最近的持久化耗时多久。当我们监控到持久化耗时过长甚至失败的时候,就要考虑集群拆分单个Redis的规模了。
Stats模块,用来统计通用的数据,例如每秒钟数据的量,每秒钟的并发数,命中数等等等。
是一个非常非常实用的统计数据,通过这个统计数据,我们可以看到Redis的服务情况。
除此之外,Replication是主从同步的信息,CPU是CPU的统计信息,Cluster是Redis以Cluster部署的时候,集群的相关信息。
掌握了这些基础的统计项,我们只要简单地写个心跳的程序,将定时心跳的结果存放到数据库之中,再写一个简单的网页,把数据的结果通过表格的形式展示出来,就是一个可用的Redis可视化监控系统了。当然,一个好的监控系统,除了要展示数据,还要增加告警、数据对比等功能,才会变得更加实用。
好了,今天我们介绍到这里,如果你们公司的Redis没有监控,不如尝试手写一个吧。一个会动手的开发才是一个好码农。欢迎大家关注我,整理后会和大家继续分享。大家的支持是我继续唠嗑的动力。