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-阿裏雲