[Redis]为什么这么快
redis为什么这么快
- 基于内存实现
redis将数据存储在内存中,内存的读写速度很快,所以redis速度很快 - 高效的数据结构
- 哈希表
- 跳表
- 压缩表
- 快表
- 双向链表
- 简单动态字符串
- 整数数组
- 单线程模型
- 使用IO多路复用
- 合理的数据编码
Redis为什么会比MySQL快?
1.(内存和磁盘的区别)Redis是基于内存存储的,MySQL是基于磁盘存储的
2.(哈希索引和B+树索引的区别)Redis存储的是k-v格式的数据。时间复杂度是O(1),常数阶,而MySQL引擎的底层实现是B+Tree,时间复杂度是O(logn),对数阶。Redis会比MySQL快一点点。
3.MySQL数据存储是存储在表中,查找数据时要先对表进行全局扫描或者根据索引查找,这涉及到磁盘的查找,磁盘查找如果是按条点查找可能会快点,但是顺序查找就比较慢;而Redis不用这么麻烦,本身就是存储在内存中,会根据数据在内存的位置直接取出。
4.(单线程和多线程的区别)Redis是单线程的多路复用IO,单线程避免了线程切换的开销,而多路复用IO避免了IO等待的开销,在多核处理器下提高处理器的使用效率可以对数据进行分区,然后每个处理器处理不同的数据。