首页 数据库 Redis Redis运维之缓冲区

Redis运维之缓冲区

May 21, 2020 am 09:28 AM
1

可能很多开发者都认为Redis很简单,掌握些api不就可以了么。事实上,如果使用不当,会出现很多问题的。今天,就来说说redis的缓冲。Redis给客户端提供了输入缓冲区与输出缓冲区,并且提供了相应的api来查看监控缓冲区。

输入缓冲区

Redis为每个客户端都提供了输入缓冲区,它的作用是将客户端发来的命令保存,然后Redis会从输入缓冲区中提取命令并执行。

Redis为客户端提供的输入缓冲区大小是有限制的,不能超过1G内存,超过的话Redis将关闭该客户端。

缓冲区溢出的危害

每个客户端的输入缓冲区最大不能超过1G,超过的话,该客户端将会被关闭,将会造成应用出问题。

输入缓冲区不能大小不受maxmory控制,当maxmory设置为8G时,当Redis已存储了4G数据,而所有客户端的输入缓冲区总大小为5G时,将可能造成数据丢失,键值淘汰,OOM等情况。

缓冲区溢出的原因,是因为redis的处理速度赶不上缓冲区的输入速度。常见的情况是,输入缓冲区内含有大量bigkey或redis发生了阻塞。

监控

监控输入缓冲区有两种方法

  • 第一种方法是通过client list命令来查看目前所有连接的客户端信息

  • 第二种方法是通过info clients命令查看总体的信息。

127.0.0.1:6379> client list
id=113430 addr=127.0.0.1:57244 fd=7 name= age=3115 idle=0 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=26 qbuf-free=32742 obl=0 oll=0 omem=0 events=r cmd=client
id=113432 addr=127.0.0.1:57250 fd=9 name= age=3099 idle=342 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=0 obl=0 oll=0 omem=0 events=r cmd=set
……
登录后复制

其中,和输入缓冲区有关的是qbuf、qbuf-free,他们分别表示输入缓冲区的大小和剩余的输入缓冲区的大小。

127.0.0.1:6379> info clients
# Clients
connected_clients:4
client_recent_max_input_buffer:2
client_recent_max_output_buffer:0
blocked_clients:0
登录后复制

client_recent_max_input_buffer表示最大的输入缓冲区的大小。

这两种方法有自己的优缺点:

  • client list可以精确监控每个客户端情况,但执行速度较慢,有可能造成redis阻塞。

  • info clients 执行快,但分析的数据较简单,不能精确到每个客户端,且不能显示总的客户端输入缓冲区大小,只显示最大的。

输出缓冲区

Redis也提供了输出缓冲区,和输入缓冲区一样,输出缓冲区也不受maxmory控制。

但和输入缓冲区不一样的是,输出缓冲区可以通过配置文件来限制。

client-output-buffer-limit type hardlimit softlimit secords

  • type表示客户端类型

  • hardlimit 输出缓冲区最大值,超过的话会立即关闭

  • sortlimit 及secords 当超过sortlimit限制secords秒后,客户端会被关闭。

Redis默认配置如下:

client-output-buffer-limit normal 0 0 0
client-output-buffer-limit replica 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
登录后复制

监控

和输出缓冲区监控的办法一样,也会使用client list及info clients。

client list中和输出缓冲相关的是obl、oll、omem,主要看omem,它表示输出缓冲区的大小。

info clients中client_recent_max_output_buffer表示最大的输出缓冲区大小。

他们的优缺点和之前所说一样,这里就不赘述。

另外这里再介绍一个命令,用来关闭客户端的连接。

client kill ip:端口

当发现客户端异常时,就可以使用该命令来关闭异常的连接。

以上是Redis运维之缓冲区的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何在Redis中实施身份验证和授权? 如何在Redis中实施身份验证和授权? Mar 17, 2025 pm 06:57 PM

本文讨论了在REDIS中实施身份验证和授权,重点是实现身份验证,使用ACL以及确保REDIS的最佳实践。它还涵盖了管理用户权限和工具以增强重新安全性。

如何在Redis群集中选择一个碎片键? 如何在Redis群集中选择一个碎片键? Mar 17, 2025 pm 06:55 PM

本文讨论了在Redis群集中选择碎片键,并强调了它们对性能,可伸缩性和数据分布的影响。关键问题包括确保均匀数据分配,与访问模式保持一致以及避免常见错误l

如何将Redis用于工作队列和背景处理? 如何将Redis用于工作队列和背景处理? Mar 17, 2025 pm 06:51 PM

本文讨论了使用REDIS进行工作队列和背景处理,详细的设置,作业定义和执行。它涵盖了原子运营和工作优先级等最佳实践,并解释了REDIS如何提高处理效率。

如何在REDIS中实施缓存无效策略? 如何在REDIS中实施缓存无效策略? Mar 17, 2025 pm 06:46 PM

本文讨论了在REDIS中实施和管理缓存无效的策略,包括基于时间的到期,事件驱动的方法和版本控制。它还涵盖了缓存到期的最佳实践和监视和自动的工具

如何监视REDIS群集的性能? 如何监视REDIS群集的性能? Mar 17, 2025 pm 06:56 PM

文章讨论了使用Redis CLI,Redis Insight和Datadog和Prometheus等工具等工具进行监视REDIS群集的性能和健康。

如何将Redis用于酒吧/子消息传递? 如何将Redis用于酒吧/子消息传递? Mar 17, 2025 pm 06:48 PM

本文介绍了如何将Redis用于酒吧/子消息传递,涵盖设置,最佳实践,确保消息可靠性和监视性能。

如何在Web应用程序中使用REDI进行会话管理? 如何在Web应用程序中使用REDI进行会话管理? Mar 17, 2025 pm 06:47 PM

本文讨论了在Web应用程序中使用REDIS进行会话管理,详细介绍设置,诸如可伸缩性和性能以及安全措施之类的好处。

如何确保重新侵害常见漏洞? 如何确保重新侵害常见漏洞? Mar 17, 2025 pm 06:57 PM

文章讨论了确保重新侵害漏洞,重点关注强密码,网络绑定,命令禁用,身份验证,加密,更新和监视。

See all articles