193
阿里云
事务处理__最佳实践_云数据库 Redis 版-阿里云
事务处理(transaction)
场景介绍
ApsaraDB for Redis 支持 Redis 中 定义的“事务(transaction)”机制,即用户可以使用 MULTI,EXEC,DISCARD,WATCH,UNWATCH 指令用来执行原子性的事务操作。
需要强调的是,Redis 中定义的事务,并不是关系数据库中严格意义上的事务。当 Redis 事务中的某个操作执行失败,或者用 DISCARD 取消事务时候,Redis 并不执行“事务回滚”,在使用时要注意这点。
代码示例1:两个 client 操作不同的 key
package transcation.kvstore.aliyun.com;import java.util.List;import redis.clients.jedis.Jedis;import redis.clients.jedis.Transaction;public class KVStoreTranscationTest {static final String host = "xxxxxx.m.cnhza.kvstore.aliyuncs.com";static final int port = 6379;static final String password = "password";//**注意这两个key的内容是不同的static String client1_key = "KVStore-Transcation-1";static String client2_key = "KVStore-Transcation-2";public static void main(String[] args) {Jedis jedis = new Jedis(host, port);// ApsaraDB for Redis的实例ID及密码String authString = jedis.auth(password);//passwordif (!authString.equals("OK")) {System.err.println("认证失败: " + authString);jedis.close();return;}jedis.set(client1_key, "0");//启动另一个thread,模拟另外的clientnew KVStoreTranscationTest().new OtherKVStoreClient().start();Thread.sleep(500);Transaction tx = jedis.multi();//开始事务//以下操作会集中提交服务器端处理,作为“原子操作”tx.incr(client1_key);tx.incr(client1_key);Thread.sleep(400);//此处Thread的暂停对事务中前后连续的操作并无影响,其他Thread的操作也无法执行tx.incr(client1_key);Thread.sleep(300);//此处Thread的暂停对事务中前后连续的操作并无影响,其他Thread的操作也无法执行tx.incr(client1_key);Thread.sleep(200);//此处Thread的暂停对事务中前后连续的操作并无影响,其他Thread的操作也无法执行tx.incr(client1_key);List<Object> result = tx.exec();//提交执行//解析并打印出结果for(Object rt : result){System.out.println("Client 1 > 事务中> "+rt.toString());}jedis.close();}class OtherKVStoreClient extends Thread{@Overridepublic void run() {Jedis jedis = new Jedis(host, port);// ApsaraDB for Redis的实例ID及密码String authString = jedis.auth(password);// passwordif (!authString.equals("OK")) {System.err.println("AUTH Failed: " + authString);jedis.close();return;}jedis.set(client2_key, "100");for (int i = 0; i < 10; i++) {try {Thread.sleep(300);} catch (InterruptedException e) {e.printStackTrace();}System.out.println("Client 2 > "+jedis.incr(client2_key));}jedis.close();}}}
运行结果1
在输入了正确的 ApsaraDB for Redis 实例访问地址和密码之后,运行以上 Java 程序,输出结果如下。从中可以看到 client1 和 client2 在两个不同的 Thread 中,client1 所提交的事务操作都是集中顺序执行的,在此期间尽管 client2 是对另外一个 key 进行操作,它的命令操作也都被阻塞等待,直至 client1 事务中的全部操作执行完毕。
Client 2 > 101Client 2 > 102Client 2 > 103Client 2 > 104Client 1 > 事务中> 1Client 1 > 事务中> 2Client 1 > 事务中> 3Client 1 > 事务中> 4Client 1 > 事务中> 5Client 2 > 105Client 2 > 106Client 2 > 107Client 2 > 108Client 2 > 109Client 2 > 110
代码示例2:两个 client 操作相同的 key
对以上的代码稍作改动,使得两个 client 操作同一个 key,其余部分保持不变。
... ...//**注意这两个key的内容现在是相同的static String client1_key = "KVStore-Transcation-1";static String client2_key = "KVStore-Transcation-1";... ...
运行结果2
再次运行修改后的此 Java 程序,输出结果如下。可以看到不同 Thread 中的两个 client 在操作同一个 key,但是当 client1 利用事务机制来操作这个 key 时,client2 被阻塞不得不等待 client1 事务中的操作完全执行完毕。
Client 2 > 101Client 2 > 102Client 2 > 103Client 2 > 104Client 1 > 事务中> 105Client 1 > 事务中> 106Client 1 > 事务中> 107Client 1 > 事务中> 108Client 1 > 事务中> 109Client 2 > 110Client 2 > 111Client 2 > 112Client 2 > 113Client 2 > 114Client 2 > 115
最后更新:2016-12-16 17:36:54
上一篇:
管道传输__最佳实践_云数据库 Redis 版-阿里云
下一篇:
当前支持的 Redis 版本___FAQ_云数据库 Redis 版-阿里云
OceanBase SQL简介__SQL语法参考_云数据库 OceanBase-阿里云
教程__Java-SDK_SDK手册_移动安全-阿里云
二次排序示例__示例程序_MapReduce_大数据计算服务-阿里云
数据转发到表格存储中__规则引擎_控制台使用手册_阿里云物联网套件-阿里云
CreateRole__角色管理接口_RAM API文档_访问控制-阿里云
仿冒检测示例代码__Java-SDK_SDK手册_移动安全-阿里云
附录:PPAS 开发驱动程序__快速入门(PPAS)_云数据库 RDS 版-阿里云
删除标签__标签_用户指南_云服务器 ECS-阿里云
备份和灾难恢复__使用金融云产品_金融云-阿里云
测试__产品简介_推荐引擎-阿里云
相关内容
常见错误说明__附录_大数据计算服务-阿里云
发送短信接口__API使用手册_短信服务-阿里云
接口文档__Android_安全组件教程_移动安全-阿里云
运营商错误码(联通)__常见问题_短信服务-阿里云
设置短信模板__使用手册_短信服务-阿里云
OSS 权限问题及排查__常见错误及排除_最佳实践_对象存储 OSS-阿里云
消息通知__操作指南_批量计算-阿里云
设备端快速接入(MQTT)__快速开始_阿里云物联网套件-阿里云
查询API调用流量数据__API管理相关接口_API_API 网关-阿里云
使用STS访问__JavaScript-SDK_SDK 参考_对象存储 OSS-阿里云