redis中事务(Transaction)的使用

原创 2017年09月24日 17:45:01

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,提供多种语言的API,支持多种数据存储方式。开发中一般用于缓存,队列,数据库使用。

redis事务(Transaction)说明

redis中的事务与传统关系型数据库(如mysql)的事务是不同的。

redis中的事务是一组命令的集合,事务与命令都是最小执行单位,原理是先将属于一个事务的命令发送给Redis,然后Redis一次执行这些命令。

redis的事务可以保证一个事务内的命令一次执行而不被其他命令插入影响。

redis的事务错误处理与关系型数据库事务错误处理区别

如果事务块中某一条命令出错,关系型数据库的事务会执行回滚,而redis不会执行回滚,而是会继续执行后续的命令。因为redis的事务没有关系型数据库的回滚(rollback)功能。因此需要开发者在事务执行出错时自己处理。

redis事务(Transaction)命令

1.watch
用于监视一个或多个key,如果在事务执行之前这个或(这些)key被其他命令所改动,事务将被中断。

2.unwatch
用于取消watch命令对所有key的监视。

3.multi
用于标记一个事务块的开始,之后的所有命令都存放在队列,等遇到exec命令再执行。

4.exec
用于执行事务块内所有的命令,如果命令被中断,返回false

实例

1.使用redis事务,事务正常执行

<?php
$redis = new Redis;
$redis->connect('localhost', 6379);

// 监听
$redis->watch('mykey1','mykey2');

// 开启事务块
$redis->multi();

// 事务块语句
$redis->set('mykey1', date('Y-m-d H:i:s'));
$redis->set('mykey2', time());

// 执行事务
$result = $redis->exec();

// 取消监听
$redis->unwatch();

var_dump($result);
?>

输出:

array (size=2)
  0 => boolean true
  1 => boolean true

进入redis查看这两个key的值

127.0.0.1:6379> mget "mykey1" "mykey2"
1) "2017-09-24 17:14:02"
2) "1506244442"

表示事务块语句 set mykey1,mykey2执行成功。

2.使用redis事务,事务被中断

我们模拟在事务执行过程中值被修改,因此在事务块中加入sleep延迟执行,然后在延迟的时候修改监听key的值。

<?php
$redis = new Redis;
$redis->connect('localhost', 6379);

// 监听
$redis->watch('mykey1','mykey2');

// 开启事务块
$redis->multi();

// 事务块语句
$redis->set('mykey1', date('Y-m-d H:i:s'));
$redis->set('mykey2', time());

// 延迟5秒
sleep(5);

// 执行事务
$result = $redis->exec();

// 取消监听
$redis->unwatch();

var_dump($result);
?>

在延迟的时候,进入redis,手动执行以下命令修改mykey2的值。

127.0.0.1:6379> set mykey2 123
OK

因为监听的key的值被修改,因此事务执行中止。

输出:

boolean false

进入redis查看这两个key的值

127.0.0.1:6379> mget "mykey1" "mykey2"
1) "2017-09-24 17:14:02"
2) "123"

表示事务块语句 set mykey1,mykey2没有执行。

版权声明:本文为博主原创文章,未经博主允许不得转载。如需转载可私信或关注公众号fdipzone-idea与我联系。 https://blog.csdn.net/fdipzone/article/details/78078240

Android SQLite 性能优化——显示使用事务

数据库是应用开发中常用的技术,在Android应用中也不例外。Android默认使用了SQLite,介绍实际项目中遇到大量操作数据时的处理方式; 以及原理;
  • 2016年11月23日 07:14

redis中的transaction

在The Little Redis Book一书中,提到了redis中transaction的概念,也就是事务,transaction能够保证以下特性: The commands will be ...
  • imred
  • imred
  • 2016-04-23 13:32:13
  • 338

Redis事务使用总结

Redis的事务机制允许同时执行多条指令,它是原子性操作,事务中的命令要么全部执行,要么全部不执行,另外,事务中的所有指令都会被序列化,而且其开始执行过程中,不回被即时过来的指令所打断,其需要经历三个...
  • why_2012_gogo
  • why_2012_gogo
  • 2016-04-28 15:04:56
  • 1443

一头坑进Redis之事务

一.是什么 可以一次执行多个命令,本质是一组命令的集合。
  • googleoyyp
  • googleoyyp
  • 2017-08-21 23:54:49
  • 536

关于Redis的Transaction

关于Redis的Transaction,查了很多资料,现在能实现Transaction的方法有3种: 1,使用SessionCallback 这个方法是很多资料上都推荐的,也是现在最可靠的一种。 ...
  • hotdust
  • hotdust
  • 2016-08-24 20:14:07
  • 2782

redis中事务(Transaction)的使用

本文将介绍redis中事务(Transaction)的使用,与关系型数据库(如mysql)的事务进行对比,说明redis中事务的执行方式。并提供事务执行的完整演示实例。...
  • fdipzone
  • fdipzone
  • 2017-09-24 17:45:01
  • 26677

spark访问Redis并进行操作

Redis是一种高性能的内存数据库,其应用场合非常广泛,在一些实时性要求比较高的场景中,以Redis作为架构来实现的是比较多的。 Redis提供了好几种数据结构,如Set, List, Ha...
  • sparkexpert
  • sparkexpert
  • 2016-01-07 22:58:47
  • 7803

Redis--transaction(事务)

MULTI 、 EXEC 、 DISCARD 和 WATCH 是 Redis 事务的基础。 事务可以一次执行一组命令,并且事物保证能做到如下两点: 事务是一个单独的隔离操作:事务中的所有命...
  • bemavery
  • bemavery
  • 2017-08-14 08:40:53
  • 2538

Kafka+Spark Streaming+Redis实时计算整合实践

基于Spark通用计算平台,可以很好地扩展各种计算类型的应用,尤其是Spark提供了内建的计算库支持,像Spark Streaming、Spark SQL、MLlib、GraphX,这些内建库都提供了...
  • gao634209276
  • gao634209276
  • 2016-08-16 23:29:45
  • 309

Spark&redis

转:http://www.jianshu.com/p/e91076ccc194 Spark的优势在于内存计算,然而在计算中难免会用到一些元数据或中间数据,有的存在关系型数据库中,有的存在HDFS...
  • weixin_36630761
  • weixin_36630761
  • 2017-10-19 20:28:31
  • 72
收藏助手
不良信息举报
您举报文章:redis中事务(Transaction)的使用
举报原因:
原因补充:

(最多只允许输入30个字)