linux 多任务 单线程,单进程单线程、单进程多线程和多进程单线程

我们都知道多线程可以充分利用CPU的性能,毕竟目前都是多核的,而且可以将一些I/O操作另起一个线程,避免当前线程阻塞。

但是Redis是单线程模型,也就是说不管多少个客户端连接上同一个Redis实例,它都是有一个线程来处理读写请求,严格来说这种模式是单进程单线程。那为什么Redis还是那么快呢?

完全基于内存

数据结构简单

使用多路 I/O 复用模型

多路 I/O 复用模型是利用select、poll、epoll可以同时监察多个流的 I/O 事件的能力,在空闲的时候,会把当前线程阻塞掉,当有一个或多个流有I/O事件时,就从阻塞态中唤醒,于是程序就会轮询一遍所有的流(epoll是只轮询那些真正发出了事件的流),并且只依次顺序的处理就绪的流,这种做法就避免了大量的无用操作。这里“多路”指的是多个网络连接,“复用”指的是复用同一个线程,也就是Redis中的单线程。采用多路 I/O 复用技术可以让单个线程高效的处理多个连接请求(尽量减少网络IO的时间消耗)

单进程单线程优点

代码更清晰,处理逻辑更简单

不用去考虑各种锁的问题,不存在加锁释放锁操作,没有因为可能出现死锁而导致的性能消耗

不存在多进程的切换导致消耗CPU

单进程单线程缺点

无法充分发挥多核CPU性能——可以通过开启多个Redis实例来利用多核CPU

多进程单线程模型:Nginx

其实我对Nginx了解也不多,只知道一点点相关知识。

不同于Apache,Nginx使用多进程的方法进行任务处理,每个worker进程只有一个线程,单线程循环处理全部监听的事件(是不是也有多路复用的意思在里面,果然技术很多都是相通的),而Apache对每一个连接都会起一个线程去处理。

通常一个单独的worker进程使用一个处理器核,这样能完全利用多核体系结构,并且避免线程抖动和锁。由于Nginx不为每个连接派生进程或线程,所以内存使用在大多数情况下是很节约并且高效的。同时由于不用频繁的生成和销毁进程或线程,所以Nginx也很节省CPU。

单进程多线程模型:Memcached、MySQL等

这个没用过,只知道也是个类似于Redis的一个缓存数据库。

Memcache可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS。

只支持简单的key/value数据结构,不像Redis可以支持丰富的数据类型。

无法进行持久化,数据不能备份,只能用于缓存使用,且重启后数据全部丢失。

补充:

多说一句,Memcached是基于libevent的事件处理。Linux内核提供的epoll为开发服务器提供了很大的便利,libevent和libev都是对epoll的封装,nginx自己实现了对epoll的封装。libevent和libev都是知名的Linux系统C事件驱动编程框架。所以,nginx在Windows上不像Linux快是有很大原因的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值