Redis 基础详解

码农日常1个月前更新 Trunks
577 0 0

五、Redis 的单线程和高性能

1、Redis 是单线程吗?

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

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

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

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

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

Redis 基础详解

Shell
# 查看redis支持的最大连接数,在redis.conf文件中可修改,# maxclients 10000
127.0.0.1:6379> config get maxclients
##1) "maxclients"
##2) "10000"

© 版权声明

相关文章

暂无评论

暂无评论...