How to implement Redis transactions
ACID attribute description
Atomicity
All operations in the transaction are inseparable in the database, either all are completed or none are executed.
Consistency
The execution of a transaction converts data from one state to another. Before the transaction starts and after the transaction ends, the integrity constraints of the database are not violated.
Isolation
The isolation of a transaction requires that the objects of each read-write transaction are separated from the operation objects of other transactions, that is, the transaction is not visible to other transactions before it is submitted.
Durability
After the database executes a transaction, the data modifications must be persisted. When the database is restarted, the value of the data needs to be the modified value.
How Redis implements transactions
Implementation principle
The execution of Redis transactions includes three steps, as follows:
Customer The end uses the MULTI command to explicitly start a transaction.
The server receives the specific operations sent by the client (such as adding, deleting, and modifying data) and executes them in the transaction. These operations are the data read and write commands provided by Redis itself. Although these commands are sent to the server by the client, the Redis instance only temporarily stores these commands in a command queue and does not execute them immediately.
Only when an EXEC command is received and executed, Redis will commit the transaction and actually execute all commands in the transaction queue.
Transaction related commands
MULTI: Open transaction
EXEC: Submit transaction and execute command All operation commands in the queue.
DISCARD: Abandon a transaction and clear the command queue, but the rollback of the transaction cannot be supported.
WATCH: Detect whether the value of one or more keys changes during the execution of the transaction. If it changes, then the current transaction abandons execution.
How does Redis transaction support ACID
Does Redis transaction support atomicity?
Scenario 1: An error is reported when executing the transaction when it is enqueued, then Redis will give up transaction execution to ensure transaction atomicity.
Scenario 2: The command does not report an error when it is entered into the queue, but an error is reported when it is actually executed. The atomicity of the transaction cannot be guaranteed.
Example description of case one
127.0.0.1:6379> multi OK 127.0.0.1:6379> set t1 v1 QUEUED 127.0.0.1:6379> set t2 v2 QUEUED 127.0.0.1:6379> setget t3 (error) ERR unknown command 'setget' 127.0.0.1:6379> set t4 v4 QUEUED 127.0.0.1:6379> exec (error) EXECABORT Transaction discarded because of previous errors. 127.0.0.1:6379> get t4 (nil)
Explanation: Before executing the exec command, if a syntax error occurs (a non-existent command is used), then when the command is enqueued, Redis will report an error and record the error. After the Exec command is executed, Redi will reject all submitted commands and the transaction execution will fail. In this case, Reid's transaction can support atomicity.
Example description of case two
127.0.0.1:6379> multi OK 127.0.0.1:6379> incr s2 QUEUED 127.0.0.1:6379> set a1 v1 QUEUED 127.0.0.1:6379> set a2 v2 QUEUED 127.0.0.1:6379> exec 1) (error) ERR value is not an integer or out of range 2) OK 3) OK 127.0.0.1:6379> get a2 "v2"
Explanation: The value of s2 is v2, and an error is reported when executing the incr command, because incr can only add integer type values, but in this case we found The Redis transaction is not rolled back, and subsequent commands can be executed successfully, so the atomicity of the transaction cannot be guaranteed in this case.
Does Redis transaction support consistency?
Scenario 1: An error is reported when the command is added to the queue
In the first case, the transaction itself will be abandoned, so the consistency of the transaction can be guaranteed.
Case 2: No error is reported when the command is added to the queue, but an error is reported when actually executed.
In the second case, the erroneous command will not be executed, but the correct command can be executed normally, and no error is reported when the command is executed. Will change the consistency of the database.
Scenario 3: Exec execution command Redis instance fails
If Redis persistence is set to RDB, the RDB snapshot generated will not be executed when the transaction is executed, so the transaction The results of the command operation will not be saved to the RDB snapshot. When using the RDB snapshot for recovery, the data in the database will be consistent.
If Reids persistence is set to AOF and the instance fails before the transaction operation is recorded in the AOF log, then the database data restored using the AOF log is consistent . If only some operations are recorded in the AOF log, we can use redis-check-aof to clear the completed operations in the transaction, and the database will be consistent after recovery.
Does Redis transaction support isolation?
In order to achieve Redis transaction isolation, you need to use the watch command. The principle of Watch is that when monitoring changes in one or more keys before a transaction is executed, when the transaction calls the EXEC command to execute, the WATCH mechanism will first check whether the monitored keys have been modified by other clients. If the value of the listener is modified, transaction execution is abandoned to prevent the isolation of the transaction from being destroyed.
Example Description
Client 1:
127.0.0.1:6379> get blance "100" 127.0.0.1:6379> watch blance OK 127.0.0.1:6379> multi OK 127.0.0.1:6379> decrby blance 10 QUEUED 127.0.0.1:6379> incrby blance 10 QUEUED 127.0.0.1:6379> exec (nil)
Client 2:
127.0.0.1:6379> get blance "100" 127.0.0.1:6379> set blance 90 OK 127.0.0.1:6379> get blance "90"
Description: Client 1 uses watch to detect balance, after opening the transaction , perform the operation of changing the value of balance on client 2, simulate other clients changing the data monitored by the watch during transaction execution, and then execute the EXEC command of client 1, and find that the transaction was not successfully executed.
Does Redis transaction support persistence?
Redis transactions cannot support persistence. If Redis uses RDB mode, after a transaction is executed, but before the next RDB snapshot is executed, Redis instance crashes. In this case, the transaction Modified data cannot be guaranteed to be durable. If Redis adopts the AOF mode, data loss may occur regardless of whether the persistence configuration is no, everysec or always. Therefore, no matter which persistence mode Redis adopts, the durability of the transaction will be affected. Unable to support.
The above is the detailed content of How to implement Redis transactions. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Redis cluster mode deploys Redis instances to multiple servers through sharding, improving scalability and availability. The construction steps are as follows: Create odd Redis instances with different ports; Create 3 sentinel instances, monitor Redis instances and failover; configure sentinel configuration files, add monitoring Redis instance information and failover settings; configure Redis instance configuration files, enable cluster mode and specify the cluster information file path; create nodes.conf file, containing information of each Redis instance; start the cluster, execute the create command to create a cluster and specify the number of replicas; log in to the cluster to execute the CLUSTER INFO command to verify the cluster status; make

How to clear Redis data: Use the FLUSHALL command to clear all key values. Use the FLUSHDB command to clear the key value of the currently selected database. Use SELECT to switch databases, and then use FLUSHDB to clear multiple databases. Use the DEL command to delete a specific key. Use the redis-cli tool to clear the data.

To read a queue from Redis, you need to get the queue name, read the elements using the LPOP command, and process the empty queue. The specific steps are as follows: Get the queue name: name it with the prefix of "queue:" such as "queue:my-queue". Use the LPOP command: Eject the element from the head of the queue and return its value, such as LPOP queue:my-queue. Processing empty queues: If the queue is empty, LPOP returns nil, and you can check whether the queue exists before reading the element.

Using the Redis directive requires the following steps: Open the Redis client. Enter the command (verb key value). Provides the required parameters (varies from instruction to instruction). Press Enter to execute the command. Redis returns a response indicating the result of the operation (usually OK or -ERR).

Using Redis to lock operations requires obtaining the lock through the SETNX command, and then using the EXPIRE command to set the expiration time. The specific steps are: (1) Use the SETNX command to try to set a key-value pair; (2) Use the EXPIRE command to set the expiration time for the lock; (3) Use the DEL command to delete the lock when the lock is no longer needed.

On CentOS systems, you can limit the execution time of Lua scripts by modifying Redis configuration files or using Redis commands to prevent malicious scripts from consuming too much resources. Method 1: Modify the Redis configuration file and locate the Redis configuration file: The Redis configuration file is usually located in /etc/redis/redis.conf. Edit configuration file: Open the configuration file using a text editor (such as vi or nano): sudovi/etc/redis/redis.conf Set the Lua script execution time limit: Add or modify the following lines in the configuration file to set the maximum execution time of the Lua script (unit: milliseconds)

Use the Redis command line tool (redis-cli) to manage and operate Redis through the following steps: Connect to the server, specify the address and port. Send commands to the server using the command name and parameters. Use the HELP command to view help information for a specific command. Use the QUIT command to exit the command line tool.

In Debian systems, readdir system calls are used to read directory contents. If its performance is not good, try the following optimization strategy: Simplify the number of directory files: Split large directories into multiple small directories as much as possible, reducing the number of items processed per readdir call. Enable directory content caching: build a cache mechanism, update the cache regularly or when directory content changes, and reduce frequent calls to readdir. Memory caches (such as Memcached or Redis) or local caches (such as files or databases) can be considered. Adopt efficient data structure: If you implement directory traversal by yourself, select more efficient data structures (such as hash tables instead of linear search) to store and access directory information
