• Redis事务入门及命令


    Redis 事务入门及命令

    事务概念

    数据库事务( transaction )是访问并可能操作各种数据项的一个数据库操作序列,这些操作要么全部执行,要么全部不执行,是一个不可分割的工作单位。事务由事务开始与事务结束之间执行的全部数据库操作组成。

    事务必须满足所谓的ACID属性

    Redis 事务概念

    Redis 事务的本质是一组命令的集合。事务支持一次执行多个命令,一个事务中所有命令都会被序列化。在事务执行过程,会按照顺序串行化执行队列中的命令,其他客户端提交的命令请求不会插入到事务执行命令序列中。

    总结:redis事务就是一次性、顺序性、排他性的执行一个队列中的一系列命令

    Redis 事务可以一次执行多个命令, 并且带有以下三个重要的保证:

    • 批量操作在发送 EXEC 命令前被放入队列缓存。
    • 收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行。
    • 在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。

    Redis 事务特性

    Redis事务的三个特性:

    • 单独的隔离操作:事务中的所有命令都会被序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。

    • 没有隔离级别的概念: 队列中的命令没有提交之前都不会实际被执行,因为事务提交前任何指令都不会被实际执行。

    • 不保证原子性:事务中如果有一条命令执行失败,其后的命令仍然会被执行,没有回滚。

    Redis 三个阶段

    Redis的一个事务从开始到执行会经历以下三个阶段:

    • 开始事务:使用 MULTI 开启一个事务
    • 命令入队:当开启一个事务之后,之后所有的命令不会马上被执行,而是会被放入到一个事务队列中,然后返回 QUEUED, 表示命令已入队
    • 执行事务:那么当 EXEC 命令执行时, 服务器根据客户端所保存的事务队列, 以先进先出(FIFO)的方式执行事务队列中的命令:最先入队的命令最先执行,而最后入队的命令最后执行

    入门代码示例

    以下是一个事务的例子, 它先以 MULTI 开始一个事务, 然后将多个命令入队到事务中, 最后由 EXEC 命令触发事务, 一并执行事务中的所有命令:

    redis 127.0.0.1:6379> MULTI
    OK
    
    redis 1
    • 1
    • 2
    • 3
  • 相关阅读:
    Jmeter- Beanshell语法和常用内置对象(网络整理)
    Gmail发送邮件的配置方法
    FixedWindowRollingPolicy简介说明
    【计算机视觉 | CNN】Image Model Blocks的常见算法介绍合集(二)
    如何写后端开发之接口设计文档
    【华为机试真题 JAVA】字符串加密-100
    数据结构课程笔记总结1 - 排序算法
    tcp/ip该来的还是得来
    【无标题】
    ARM寻址方式
  • 原文地址:https://blog.csdn.net/weixin_45525272/article/details/127877562