关于单进程单线程的Redis如何能够高并发?

单进程单线程的Redis如何能够高并发


拉丁的传说
浏览 1421回答 4
4回答

米琪卡哇伊

单线程,只能靠单个处理器速度,内存速度,处理器上的缓存速度,总线传输速度。余下的是你的网络IO。但线程高并发完全依赖程序的运行速度。redis这种东西肯定不是但线程的。一个连接就是一个线程,你这样理解应该不准确。

至尊宝的传说

redis是C语言写的,C是只能单线程的。但是并不代表单线程不能够做到多线程的效率和工作。多线程是并发的体现,前提是有多处理器,就一定能并发,汇编都可以写并发程序,所以也就能多线程,单线程的C肯定是可以的。在《redis深度历险》提到,nodejs,redis,nginx这样的高性能服务器,可以通过非阻塞I/O实现,具体内容可以看电子版的,或者去图书馆翻翻看

慕容3067478

MongoDB不多说,不是一个类型的东西,Redis相对Memcached来说功能和特性上的优势已经很明显了。而对于性能,Redis作者的说法是平均到单个核上的性能,在单条数据不大的情况下Redis更好。为什么这么说呢,理由就是Redis是单线程运行的。

凤凰求蛊

redis为什么会有高并发问题redis的出身决定Redis是一种单线程机制的nosql数据库,基于key-value,数据可持久化落盘。由于单线程所以redis本身并没有锁的概念,多个客户端连接并不存在竞争关系,但是利用jedis等客户端对redis进行并发访问时会出现问题。发生连接超时、数据转换错误、阻塞、客户端关闭连接等问题,这些问题均是由于客户端连接混乱造成。同时,单线程的天性决定,高并发对同一个键的操作会排队处理,如果并发量很大,可能造成后来的请求超时。在远程访问redis的时候,因为网络等原因造成高并发访问延迟返回的问题。解决法在客户端将连接进行池化,同时对客户端读写Redis操作采用内部锁synchronized。服务器角度,利用setnx变向实现锁机制。
打开App,查看更多内容
随时随地看视频慕课网APP