Redis事务和Redis管道

文章目录

  • 1.Redis事务
    • [1.1 Redis事务是什么,能干嘛?](#1.1 Redis事务是什么,能干嘛?)
    • [1.2 Redis事务和数据库事务的差异](#1.2 Redis事务和数据库事务的差异)
    • [1.3 Redis事务的相关命令](#1.3 Redis事务的相关命令)
  • 2.Redis管道
    • [2.1 Redis管道是什么](#2.1 Redis管道是什么)
    • [2.2 管道与原生批量命令对比](#2.2 管道与原生批量命令对比)
    • [2.3 管道与事务对比](#2.3 管道与事务对比)
    • [2.4 使用管道注意事项](#2.4 使用管道注意事项)

1.Redis事务

1.1 Redis事务是什么,能干嘛?

(1)Redis事务是什么?

可以一次执行多个命令,本质是一组命令的集合。一个事务中的所有命令都会序列化,按顺序地串行化执行而不会被其他命令插入,不许加塞

(2)Redis事务能干嘛?

一个队列中,一次性、顺序性、排他性的执行一系列命令

1.2 Redis事务和数据库事务的差异

1.3 Redis事务的相关命令

(1)正常执行

(2)放弃事务

(3)全体连坐

(4)冤头债主

(5)Watch监控:Redis使用Watch来提供乐观锁来锁定,类似于CAS(Check-and-Set)

①悲观锁(Pessimistic Lock), 顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁。

②乐观锁(Optimistic Lock), 顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据。乐观锁策略:提交版本必须大于 记录当前版本才能执行更新

补充:放弃监控:unwatch

2.Redis管道

2.1 Redis管道是什么

(1)Redis管道问题由来

(2)解决思路

(3)管道的定义:Pipeline是为了解决RTT往返回时间,仅仅是将命令打包一次性发送,对整个Redis的执行不造成其他任何影响。是批处理命令变种优化措施,类似Redis的原生批命令(mget和mset)

(4)演示

2.2 管道与原生批量命令对比

2.3 管道与事务对比

2.4 使用管道注意事项

相关推荐
IvorySQL34 分钟前
PostgreSQL 分区表的 ALTER TABLE 语句执行机制解析
数据库·postgresql·开源
·云扬·43 分钟前
MySQL 8.0 Redo Log 归档与禁用实战指南
android·数据库·mysql
IT邦德1 小时前
Oracle 26ai DataGuard 搭建(RAC到单机)
数据库·oracle
惊讶的猫1 小时前
redis分片集群
数据库·redis·缓存·分片集群·海量数据存储·高并发写
不爱缺氧i1 小时前
完全卸载MariaDB
数据库·mariadb
期待のcode1 小时前
Redis的主从复制与集群
运维·服务器·redis
纤纡.1 小时前
Linux中SQL 从基础到进阶:五大分类详解与表结构操作(ALTER/DROP)全攻略
linux·数据库·sql
jiunian_cn2 小时前
【Redis】渐进式遍历
数据库·redis·缓存
橙露2 小时前
Spring Boot 核心原理:自动配置机制与自定义 Starter 开发
java·数据库·spring boot
冰暮流星2 小时前
sql语言之分组语句group by
java·数据库·sql