Redis-02 单线程与高性能

Redis是单线程吗?

Redis不是只有一个线程,通常所说Redis 的单线程主要是指 Redis 的网络 IO 和键值对读写是由一个线程来完成的,这也是 Redis 对外提供键值存储服务的主要流程。但 Redis 的其他功能,比如持久化异步删除集群数据同步等,其实是由额外的线程执行的。

Redis 单线程为什么还能这么快?

因为它所有的数据都在内存中,所有的运算都是内存级别的运算,而且单线程避免了多线程的切换性 能损耗问题。正因为 Redis 是单线程,所以要小心使用 Redis 指令,对于那些耗时的指令(比如 keys),一定要谨慎使用,一不小心就可能会导致 Redis 卡顿。

Redis 单线程如何处理那么多的并发客户端连接?

Redis的IO多路复用:redis利用epoll来实现IO多路复用,将连接信息和事件放到队列中,依次放到文件事件分派器,事件分派器将事件分发给事件处理器。

Redis scan 匹配查询、分页查询

当Redis中有很多数据时,如果需要获取指定前缀的key数据,应避免使用【key *】、【keys prefix*】这种类似命令,该命令会阻塞其他数据存取操作。推荐使用【scan】

SCAN cursor [MATCH pattern] [COUNT count]

可以理解为redis的分页查询,但是不保证返回的元素条数一样,count是遍历的元素个数,非返回元素个数或页码。数据从头遍历,即游标初始值为0,返回值为下次遍历的游标值,即每次遍历都需要先根据上次返回游标值修改本次遍历游标值,直至返回游标值=0表示数据遍历完毕。

相关推荐
tod1132 小时前
Redis 分布式锁进阶:从看门狗到 Redlock 的高可用实践
数据库·redis·分布式
闲人编程2 小时前
Celery分布式任务队列
redis·分布式·python·celery·任务队列·异步化
渣瓦攻城狮2 小时前
互联网大厂Java面试:Spring、微服务与消息队列技术详解
java·redis·spring·微服务·消息队列·面试指南·程序员面试
玄〤3 小时前
个人博客网站搭建day2-Spring Boot 3 + JWT + Redis 实现后台权限拦截与单点登录(漫画解析)
java·spring boot·redis·后端·jwt
tod1133 小时前
Redis:从消息中间件到分布式核心
服务器·开发语言·redis·分布式
此生只爱蛋3 小时前
【Redis】渐进式遍历
数据库·redis·github
万象.15 小时前
redis缓存和分布式锁
redis·分布式·缓存
万象.16 小时前
redis集群算法,搭建,故障处理及扩容
redis·算法·哈希算法
白太岁16 小时前
Redis:(2) hiredis 使用、C++ 封装与连接池
c语言·c++·redis·缓存
专注VB编程开发20年21 小时前
c# vb.net Redis 左侧添加,右侧添加(添加到头部,添加到尾部)
redis·c#·.net