primers
When I read some articles recently, I saw the concept of transaction. I only remember that I have been exposed to it in a very early time, but I can’t remember what it is useful for. After searching the information, I found that it is still very useful.
introduce
Transaction processing is the processing of information in computer science that is broken down into a single, indivisible operation called a Transaction. Each transaction as a complete unit must succeed or fail and cannot be partially completed. Transactions maintain system integrity in a known consistent state by ensuring that all interdependent operations on the system are successfully completed or cancelled.
For example, a typical bank transaction transfers 100 from a customer’s savings account to a customer’s checking account. This transaction involves at least two separate operations: debiting the savings account 100 and debiting the checking account 100. If one operation succeeds and the other fails, the bank’s books end up unbalanced. There must be a way to ensure that all operations succeed or fail so that there are no inconsistencies in the bank’s overall database.
When multiple operations are linked in a transaction, ensure that all operations complete without error or fail. If some of these operations complete but errors occur while trying others, the transaction processing system rolls back all operations of the transaction (including those that have succeeded), eliminating all traces of the transaction and restoring the system to the consistent known state in which it was before the transaction began. If all operations on a transaction successfully complete, the transaction is committed by the system, and all changes to the database are permanent and cannot be rolled back once the transaction completes.
Typically, transactions are published at the same time, and conflicts can occur if they overlap. For example, if a customer has 150 in a savings account and tries to transfer 100 to another person and 100 to a checking account, only one of them will succeed. However, forcing transactions to be executed sequentially is inefficient. Thus, the concurrent programming implementation of transaction processing ensures that the end result is not conflicting and is the same as that achieved when any sequential transaction is executed. In this case, this means that regardless of whether the transaction is published first, whether the transfer to another person or to a checking account succeeds, the other operation will fail.
methods
The basic principles of all transaction processing systems are the same. However, the terminology may vary from transaction system to transaction system, and the terms used below are not necessarily generic.
Rollback
Transaction processing systems ensure database integrity by recording the intermediate state of the database when it is modified, and then using these records to restore the database to a known state if a transaction fails to commit.
Rollforward
You can keep a separate log of all changes to the database management system. This is not required for rollback, but it is useful to update the data management system in the event of a database failure, so some transaction processing systems provide it. If the database management system fails completely, it must be restored from the most recent backup. The backup does not reflect the transactions committed since the original. However, once the DATABASE management system is recovered, logs can be applied to the database (rollForward) to keep the database management system up to date.
Deadlock
In some cases, two transactions may attempt to access the same part of the database at the same time as they are being processed, preventing them from continuing. For example, transaction A accesses DATABASE X and transaction B accesses database Y. If at this point, transaction A tries to access Y of the database, and transaction B tries to access X of the database, A Deadlock is created, and neither transaction can continue.
Transaction processing systems are designed to detect when these deadlocks occur. Typically, both transactions will be cancelled and rolled back, and then they will automatically start again in a different order so that no deadlocks occur. Or sometimes, only one of the deadlocked transactions will be cancelled and rolled back, restarting automatically after a short delay.
Deadlocks may involve three or more transactions. The more transactions involved, the harder they are to detect, so there is a practical limit to how many deadlocks a transaction processing system can detect.
Compensating transaction
In systems where commit and rollback mechanisms are unavailable or not expected, compensation transactions are often used to undo failed transactions and restore the system to its previous state.
The ACID standard
Jim Gray defined the properties of a reliable transactional system in the 1970s, abbreviating ACID – Atomicity, consistency, Isolation, durability.
Atomicity
The changes to the state of a transaction are atomic: either all or none.
Consistency
A transaction is a correct transition of state. Actions taken as a group do not violate any integrity constraints associated with the state.
Isolation
Even though transactions execute concurrently, for each transaction T, other transactions appear to execute before or after T, but not at the same time.
Durability
Once the transaction completes successfully (commit), its changes to the database will survive the database failure and retain its changes.
advantages
Transaction processing has the following advantages:
- It allows users to share computer resources with each other
- It converts the time of job processing reasonably
- It avoids idle computing resources without human interaction and oversight
- It is used on expensive computers to help spread costs by keeping utilization of these expensive resources high
disadvantages
Transaction processing has the following disadvantages:
- They have relatively expensive setup costs
- Lack of a standard format
- Hardware and software are incompatible
The resources
- Transaction processing