iis服务器助手广告
返回顶部
首页 > 资讯 > 数据库 >Redis高延迟时会发生什么
  • 347
分享到

Redis高延迟时会发生什么

2024-04-02 19:04:59 347人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关Redis高延迟时会发生什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Redis 是一种内存数据库,将数据保存在内存中,读写

这篇文章将为大家详细讲解有关Redis高延迟时会发生什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

Redis 是一种内存数据库,将数据保存在内存中,读写效率要比传统的将数据保存在磁盘上的数据库要快很多。但是 Redis 也会发生延迟时,这是就需要我们对其产生原因有深刻的了解,以便于快速排查问题,解决 Redis的延迟问题。

一条命令执行过程

在本文场景下,延迟 (latency) 是指从客户端发送命令到客户端接收到命令返回值的时间间隔。所以我们先来看一下 Redis 一条命令执行的步骤,其中每个步骤出问题都可能导致高延迟。

Redis高延迟时会发生什么

上图是 Redis 客户端发送一条命令的执行过程示意图,绿色的是执行步骤,而蓝色的则是可能出现的导致高延迟的原因。

网络连接限制、网络传输速率和CPU性能等是所有服务端都可能产生的性能问题。但是 Redis 有自己独有的可能导致高延迟的问题:命令或者数据结构误用、持久化阻塞和内存交换。

而且更为致命的是,Redis 采用单线程和事件驱动的机制来处理网络请求,分别有对应的连接应答处理器,命令请求处理器和命令回复处理器来处理客户端的网络请求事件,处理完一个事件就继续处理队列中的下一个。一条命令处理出现了高延迟会影响接下来处于排队状态的其他命令。有关 Redis 事件处理机制的可以参考本篇文章。

Redis高延迟时会发生什么

对于高延迟,Redis 原生提供慢查询统计功能,执行 slowlog get {n} 命令可以获取最近的 n 条慢查询命令,默认对于执行超过10毫秒(可配置)的命令都会记录到一个定长队列中,线上实例建议设置为1毫秒便于及时发现毫秒级以上的命令。 

# 超过 slowlog-log-slower-than 阈值的命令都会被记录到慢查询队列中     # 队列最大长度为 slowlog-max-len     slowlog-log-slower-than 10000     slowlog-max-len 128

如果命令执行时间在毫秒级,则实例实际OPS只有1000左右。慢查询队列长度默认128,可适当调大。慢查询本身只记录了命令执行时间,不包括数据网络传输时间和命令排队时间,因此客户端发生阻塞异常 后,可能不是当前命令缓慢,而是在等待其他命令执行。需要重点比对异常和慢查询发生的时间点,确认是否有慢查询造成的命令阻塞排队。

slowlog的输出格式如下所示。第一个字段表示该条记录在所有慢日志中的序号,最新的记录被展示在最前面;第二个字段是这条记录被记录时的系统时间,可以用 date 命令来将其转换为友好的格式第三个字段表示这条命令的响应时间,单位为 us (微秒);第四个字段为对应的 Redis 操作。 

> slowlog get     1) 1) (integer) 26     2) (integer) 1450253133     3) (integer) 43097     4) 1) "flushdb"

下面我们就来依次看一下不合理地使用命令或者数据结构、持久化阻塞和内存交换所导致的高延迟问题。

不合理的命令或者数据结构

一般来说 Redis 执行命令速度都非常快,但是当数据量达到一定级别时,某些命令的执行就会花费大量时间,比如对一个包含上万个元素的 hash 结构执行 hgetall 操作,由于数据量比较大且命令算法复杂度是 O(n),这条命令执行速度必然很慢。

这个问题就是典型的不合理使用命令和数据结构。对于高并发的场景我们应该尽量避免在大对象上执行算法复杂度超过 O(n) 的命令。对于键值较多的 hash 结构可以使用 scan 系列命令来逐步遍历,而不是直接使用 hgetall 来全部获取。

Redis 本身提供发现大对象的工具,对应命令:redis-cli-h {ip} -p {port} bigkeys。这条命令会使用 scan 从指定的 Redis DB 中持续采样,实时输出当时得到的 value 占用空间最大的 key 值,并在最后给出各种数据结构的 biggest key 的总结报告。 

> redis-cli -h host -p 12345--bigkeys      # Scanning the entire keyspace to find biggest keys as well as      # average sizes per key type.  You can use -i 0.1 to sleep 0.1 sec      # per 100 SCAN commands (not usually needed).      [00.00%] Biggest hash   found so far 'idx:user'with2 fields      [00.00%] Biggest hash   found so far 'idx:product'with4 fields      [00.00%] Biggest hash   found so far 'idx:order'with24 fields      [02.29%] Biggest hash   found so far 'idx:fund'with26 fields      [02.29%] Biggest hash   found so far 'idx:pay'with79 fields      [04.45%] Biggestset    found so far 'indexed_Word_set'with2482 members      [05.93%] Biggest hash   found so far 'idx:address'with259 fields      [11.79%] Biggest hash   found so far 'idx:reply'with296 fields      -------- summary -------      Sampled1484 keys in the keyspace!      Total key length in bytes is13488(avg len 9.09)      Biggestset found 'indexed_word_set' has 1482 members      Biggest   hash found 'idx:的' has 196 fields      0 strings with0 bytes (00.00% of keys, avg size 0.00)      0 lists with0 items (00.00% of keys, avg size 0.00)      2 sets with2710 members (00.13% of keys, avg size 855.00)      1482 hashs with7731 fields (99.87% of keys, avg size 4.54)      0 zsets with0 members (00.00% of keys, avg size 0.00)

持久化阻塞

对于开启了持久化功能的Redis节点,需要排查是否是持久化导致的阻 塞。持久化引起主线程阻塞的操作主要有:fork 阻塞、AOF刷盘阻塞。

fork 操作发生在 RDB 和 AOF 重写时,Redis 主线程调用 fork 操作产生共享内存的子进程,由子进程完成对应的持久化工作。如果 fork 操作本身耗时过长,必然会导致主线程的阻塞。

Redis高延迟时会发生什么

Redis 执行 fork 操作产生的子进程内存占用量表现为与父进程相同,理论上需要一倍的物理内存来完成相应的操作。但是 linux 具有写时复制技术 (copy-on-write),父子进程会共享相同的物理内存页,当父进程处理写请求时会对需要修改的页复制出一份副本完成写操作,而子进程依然读取 fork 时整个父进程的内存快照。所以,一般来说,fork 不会消耗过多时间。

可以执行 info stats命令获取到 latestforkusec 指标,表示 Redis 最近一次 fork 操作耗时,如果耗时很大,比如超过1秒,则需要做出优化调整。 

> redis-cli -c -p 7000 info | grep -w latest_fork_usec     latest_fork_usec:315

当我们开启AOF持久化功能时,文件刷盘的方式一般采用每秒一次,后 台线程每秒对AOF文件做 fsync 操作。当硬盘压力过大时,fsync 操作需要等待,直到写入完成。如果主线程发现距离上一次的 fsync 成功超过2秒,为了数据安全性它会阻塞直到后台线程执行 fsync 操作完成。这种阻塞行为主要是硬盘压力引起,可以查看 Redis日志识别出这种情况,当发生这种阻塞行为时,会打印如下日志: 

Asynchronous AOF fsync is taking too long(disk is busy). \      Writing the AOF buffer without waiting for fsync to complete, \      this may slow down Redis.

也可以查看 info persistence 统计中的 aofdelayedfsync 指标,每次发生 fdatasync 阻塞主线程时会累加。 

>info persistence     loading:0     aof_pending_bio_fsync:0     aof_delayed_fsync:0

内存交换

内存交换(swap)对于 Redis 来说是非常致命的,Redis 保证高性能的一个重要前提是所有的数据在内存中。如果操作系统把 Redis 使用的部分内存换出到硬盘,由于内存与硬盘读写速度差几个数量级,会导致发生交换后的 Redis 性能急剧下降。识别 Redis 内存交换的检查方法如下:

>redis-cli -p 6383 info server | grep process_id # 查询 redis 进程号    >cat /proc/4476/smaps | grep Swap# 查询内存交换大小    Swap: 0 kB    Swap: 4 kB    Swap: 0 kB    Swap: 0 kB

如果交换量都是0KB或者个别的是4KB,则是正常现象,说明Redis进程内存没有被交换。

有很多方法可以避免内存交换的发生。比如说:

  •  保证机器充足的可用内存

  •  确保所有Redis实例设置最大可用内存(maxmemory),防止极端情况下 Redis 内存不可控的增长。

  •  降低系统使用swap优先级,如 echo10>/proc/sys/vm/swappiness。 

关于Redis高延迟时会发生什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: Redis高延迟时会发生什么

本文链接: https://www.lsjlt.com/news/68230.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Redis高延迟时会发生什么
    这篇文章将为大家详细讲解有关Redis高延迟时会发生什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Redis 是一种内存数据库,将数据保存在内存中,读写...
    99+
    2024-04-02
  • 香港服务器为什么会延迟高
    香港服务器会延迟高的原因有:1、香港服务器带宽跑满导致;2、香港服务器搭建的WEB网站受到攻击导致;3、香港服务器中毒导致;4、香港服务器本地网络出现故障导致;5、香港服务器的骨干网络节点出现故障导致。具体内容如下:检查我们的服务器上带宽使...
    99+
    2024-04-02
  • 服务器网速延迟为什么会高
    服务器网速延迟高可能有多种原因,包括但不限于以下几点: 网络拥塞:服务器所在的网络繁忙或者拥塞,导致数据传输速度变慢,延迟增加。...
    99+
    2024-04-09
    服务器
  • 香港服务器为什么会网络延迟高
    香港服务器会网络延迟高的原因有:1、香港服务器的带宽资源跑满导致;2、香港服务器部署的WEB网站受到攻击导致;3、香港服务器受到木马病毒的影响导致;4、香港服务器本地网络出现故障导致;5、香港服务器的骨干网络节点出现故障导致。具体内容如下:...
    99+
    2024-04-02
  • 网络延迟高是什么
    网络延迟高是什么?网络延迟高是指在网络通信中,传输数据所需的时间延迟较长的现象。它是网络性能的一个重要指标,直接影响着用户体验和应用程序的运行效率。网络延迟高可能出现在各种网络环境中,包括有线网络和无线网络。造成网络延迟高的原因有很多。 ...
    99+
    2024-01-24
    网络延迟高 网络延迟高是什么 云服务器知识
  • 低价美国服务器为什么会网速延迟高
    低价美国服务器网速延迟高的原因有:1、接入美国服务器链路中单个共享进程过多,导致网络延迟高,网络速度变慢;2、美国服务器的带宽不足导致网速延迟高;3、美国服务器的网络配置需求不足导致网速延迟高;4、不定期维护美国服务器导致网速延迟高;5、网...
    99+
    2024-04-02
  • 便宜的服务器租用网络延迟为什么会高
    便宜服务器租用网络延迟高的原因有:1、浏览网络服务器的用户过多,接入服务器链接单由分享过程自然就多了,网络延时就会变高;2、服务器的带宽不够,导致很多内容丢失,网络速度变慢;3、网络服务器的特性不足,解决信息内容时回应慢,网络速度变慢;4、...
    99+
    2024-04-02
  • Spring延迟初始化会遇到什么问题
    本篇文章和大家了解一下Spring延迟初始化会遇到什么问题。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。List<坑> 坑列表 = new ArrayList<>(2);首先,让我们回顾一下 Sp...
    99+
    2023-08-03
  • Linux时间延迟及延缓操作方法是什么
    这篇文章主要讲解了“Linux时间延迟及延缓操作方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux时间延迟及延缓操作方法是什么”吧!在内核中计时的头函数是#includeHz...
    99+
    2023-06-17
  • Redis实现延迟队列的方法是什么
    这篇文章主要介绍“Redis实现延迟队列的方法是什么”,在日常操作中,相信很多人在Redis实现延迟队列的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Redis实现延迟队列的方法是什么”的疑惑有所...
    99+
    2023-07-05
  • ip代理高延迟的原因是什么
    这篇文章主要为大家展示了“ip代理高延迟的原因是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“ip代理高延迟的原因是什么”这篇文章吧。1、自身网环境问题,当自己的局域网环境发生波动时,那么局...
    99+
    2023-06-15
  • JavaScript什么时候会发生自动转换
    这篇文章主要介绍了JavaScript什么时候会发生自动转换,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JavaScript可以自由的进行数据类型转换,也提供了多种显式转换...
    99+
    2023-06-29
  • 如果 MySQL 会话结束,MySQL 临时表会发生什么?
    如果 MySQL 会话终止,临时表将被删除。再次登录后,在发出 SELECT 命令时,我们将发现数据库中没有可用数据。甚至我们的临时表也不存在。...
    99+
    2023-10-22
  • 美国服务器网络延迟高是什么原因
    美国服务器网络延迟高的原因是:1、服务器链路中路由转发进程过多导致;2、美国服务器带宽不足导致;3、美国服务器配置问题导致服务器性能不够,从而影响网络速度;4、美国服务器管理不善,导致出现大量垃圾文件影响服务器速度;5、美国服务器正在遭受大...
    99+
    2024-04-02
  • 免费ip代理延迟那么高的原因是什么
    这篇文章将为大家详细讲解有关免费ip代理延迟那么高的原因是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。许多用户在购买代理IP后,在使用过程中发现延迟高这一问题,延迟高也就是说,网络会变得非常卡,尤其...
    99+
    2023-06-20
  • 美国服务器网速延迟高的原因是什么
    美国服务器网速延迟高的原因可能包括以下几点: 网络拥堵:美国是全球网络使用量最大的国家之一,网络拥堵可能导致服务器响应速度变慢。 ...
    99+
    2024-04-09
    美国服务器 服务器
  • redis缓存延时双删指的是什么
    本文小编为大家详细介绍“redis缓存延时双删指的是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“redis缓存延时双删指的是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识...
    99+
    2024-04-02
  • 定时任务实现的关键DelayQueue延迟队列是什么
    定时任务实现的关键DelayQueue延迟队列是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。今天学习是并发包提供的延迟队列(DelayQueue)。延迟队列说明延迟队...
    99+
    2023-06-19
  • 亚马逊服务器延迟高的原因是什么引起的
    如果您在使用亚马逊云平台时遇到了服务器延迟高的问题,可以尝试以下几种解决方案: 1.检查服务器硬件是否出现故障,如是否有可用备件、是否需要维修等。 2.检查服务器负载均衡器和网络设置,确保它们可以有效地分发流量并避免负载不均衡的情况。 3....
    99+
    2023-10-27
    亚马逊 原因 服务器
  • redis什么时候发布的
    小编给大家分享一下redis什么时候发布的,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!redis什么时候出的?redis的初始版本是在2009年5月10日出的。 开发者是Salvatore ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作