redis网络模型
redis是基于reactor模式设计的内存数据库。
使用reactor模型的好处:
- 使用 I/O 多路复用来实现对外部请求的处理,可以减少网络连接和读写等待时间。
- 在网络 I/O 操作中能并发处理大量的客户端请求,实现高吞吐率,高并发。
redis是单线程
redis 单线程是指其网络事件处理模型 reactor 是单线程,即指令的执行是在单线程上操作。但是其包括IO读取,网络IO操作都是通过多线程执行的。
单线程的优点:
- 采用单线程,避免了不必要的上下文切换和竞争条件;不存在多线程导致的切换而消耗CPU
- 不用考虑各种锁的问题,不存在加锁和释放锁的的操作,没有因为可能出现的死锁而导致的性能消耗
- 简单可维护,多线程模式会使得程序的编写更加复杂和麻烦,单线程实现易实现
redis pipeline
redis pipeline 是一个客户端提供的机制,指将多个命令同时发送给redis服务端.
例如多个连续的incr指令,使用pipeline(管道)后,多个连续的incr指令会被统一写到发送缓冲区,只会花费一次网络来回开销,这个开销会随着n数值的增大,大幅减少网络io开销,从而提升整体服务的性能。
但是当发送缓冲区或者接收缓冲区满了的话,也会导致阻塞。导致客户端负载过重,整个请求时间变长。所以在使用pipeline时需要注意发送指令的大小。