面试题1:redis为什么是线程安全的? Redis是个单线程程序,所以它是线程安全的。 redis实际上是采用了线程封闭的观念, 把任务封闭在一个线程,自然避免了线程安全问题, 不过对于需要依赖多个redis *** 作的复合 *** 作来说, 依然需要锁,而且有可能是分布式锁。 面试题2:redis可以能够快速执行的原因: (1) 绝大部分请求是纯粹的内存 *** 作(非常快速) (2) 采用单线程,避免了不必要的上下文切换和竞争条件 (3) 非阻塞IO - IO多路复用(IO 多路复用是什么意思?) IO多路复用中有三种方式:select,poll,epoll。 需要注意的是,select,poll是线程不安全的,epoll是线程安全的 redis内部实现采用epoll,采用了epoll+自己实现的简单的事件框架。 epoll中的读、写、关闭、连接都转化成了事件, 然后利用epoll的多路复用特性, 绝不在io上浪费一点时间 这3个条件不是相互独立的, 特别是第一条,如果请求都是耗时的, 采用单线程吞吐量及性能可想而知了。 应该说redis为特殊的场景选择了合适的技术方案。 面试题3:使用Redis有哪些好处?: 速度快,因为数据存在内存中, 类似于HashMap,HashMap的优势就是查找和 *** 作的时间复杂度都是O(1) 支持丰富数据类型,支持string,list,set,sorted set,hash 支持事务, *** 作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行 丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除
工作中使用redis必然是redis连接池,连接池可以手动关闭连接, 但是没必要,python自动做好了这件事情。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)