一、redis似乎并沒有“事務”,那些用到“事務”的人在做什么
Redis主要是針對單個key,或者說,單個數據對象的操作,這樣,事務里的多對象Atomic要求就很低。
當Redis的命令執行多對象操作,比如MSET命令,或者Redis的Transaction命令(也含LUA),涉及多數據對象時,其內部,是順序執行的(這也是我們說的,Redis是單線程架構),相當于傳統DB的Serialize級別。這時,ACID里的Isolation在Redis里就極其簡化,因為不存在兩個并發事務互相的干擾,即Redis不存在并發命令。
Redis的Transaction命令,不是嚴格意義的事務,因為缺乏Rollback。
磁盤的AOF或RDB文件,只是個備份,不是傳統意義上的DB的Dataset包含磁盤數據的概念,所以,把Redis的磁盤數據,看成整個Dataset的一部分,是不對的,還是只考慮Redis的內存特性,即它是內存數據庫。
Redis 只是提供了簡單的事務功能。其本質是一組命令的集合,事務支持一次執行多個命令,在事務執行過程中,會順序執行隊列中的命令,其他客戶端提交的命令請求不會插入到本事務執行命令序列中。命令的執行過程是順序執行的,但不能保證原子性。無法像 MySQL 那樣,有隔離級別,出了問題之后還能回滾數據等高級操作。
延伸閱讀:
二、Redis事務的應用場景
在分布式系統和高并發場景下,事務處理具有重要意義。Redis事務可以確保數據的一致性,避免并發操作導致的數據不一致問題。以下是一些Redis事務的應用場景:
批量操作:Redis 事務可以將多個命令打包成一個單元來執行,可以減少與 Redis 服務器的通信次數,從而提高性能。數據庫遷移:在遷移數據時,需要保證數據一致性。通過Redis事務,可以確保數據在遷移過程中不會出現不一致的情況。分布式鎖:在分布式系統中,為了保證數據的一致性,需要實現分布式鎖。通過Redis事務,可以在同一個事務中執行鎖定、解鎖等操作,確保鎖的原子性。這些應用場景展示了Redis事務在實際應用中的價值。接下來,我們將詳細介紹Redis事務的基本命令、特性和實現原理。