Redis(三):事务和事件


前言

`

一、redis中的事务

一个事务包含了多个命令,服务器在执行事务期间,不会改去执行其他客户端的命令请求。
事务中的多个命令被一次性发送给服务器,而不是一条一条发送,这种方式被称为流水线,他可以减少客户端和服务器之间的网络通信次数从而提高性能。
Redis最简单的事务实现方式是使用MULTI和EXEC命令将事务操作包围起来。

二、redis中的事件

事件是redis中更细粒度的动作。
redis服务器实际上是一个事件驱动程序。
文件事件:
服务器通过套接字和客户端或者其他服务器进行通信,文件事件就是对套接字操作的抽象。Redis基于Reactor模式开发了自己的网络事件处理器,使用多路复用程序来同时监听多个套接字,并将到达的事件传送给文件事件分派器,分派器会根据套接字产生的事件类型调用相应的事件处理器。
请添加图片描述

1. 时间事件
服务器有一些操作需要在给定的时间点执行,时间事件是对这类定时操作的抽象。
时间事件又分为:
定时事件:让一段程序在指定的时间执行一次。
周期性事件:让一段程序每隔指定时间就执行一次。
Redis将所有时间事件都放在一个无序的链表中,通过遍历整个链表查找已到达的时间事件并且调用相应的事件处理器。

2.事件的调度和执行
服务器需要不断监听文件事件的套接字才能得到待处理的文件事件,但是不能一直监听,否则时间事件无法在规定的时间内执行,因此监听时间应该根据距离现在最近的时间事件来决定。
请添加图片描述

总结

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值