Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

atomic operations and atomic transactions

Tags:

atomic

Can someone explain to me, whats the difference between atomic operations and atomic transactions? Its seems to me that these two are the same thing.Is that correct?

like image 542
user2204378 Avatar asked Mar 27 '13 12:03

user2204378


3 Answers

The concept of Atomicity is common between atomic transactions and atomic operations, but they are usually related to different domains.

Atomic Transactions are associated with Database operations where a set of actions must ALL complete or else NONE of them complete. For example, if someone is booking a flight, you want to both get payment AND reserve the seat OR do neither. If either one were allowed to succeed without the other also succeeding, the database would be inconsistent.

Atomic Operations on the other hand are usually associated with low-level programming with regards to multi-processing or multi-threading applications and are similar to Critical Sections. For example, if two threads both access and modify the same variable, each thread goes through the following steps:

  1. Read the variable from storage into local memory.
  2. Modify the value in local memory.
  3. Write the modified value back to the original storage location.

But in a multi-threaded system an interrupt or other context switch might happen after the first process has read the value but has not written it back. The second process (or interrupt) will then read and modify the OLD value and write its modified value back to storage. When the first process is re-enabled, it doesn't know that something might have changed so it writes back its change to the original value. Hence the operation that the second process did to the variable will be lost. If an operation is atomic, it is guaranteed to complete without being interrupted once it begins. This is usually accomplished using hardware-level primitives like Test-and-Set or Compare-and-Swap.

like image 51
Charley Moore Avatar answered Oct 17 '22 17:10

Charley Moore


To get a wider picture, you can take a look at:

  • MySQL Transactions and Atomic Operations
  • Atomicity (database systems)
  • Atomicity (Programming)

Some quotes from the above-cited resources:

About databases:

In an atomic transaction, a series of database operations either all occur, or nothing occurs. A guarantee of atomicity prevents updates to the database occurring only partially, which can cause greater problems than rejecting the whole series outright. In other words, atomicity means indivisibility and irreducibility.

About programming:

In concurrent programming, an operation (or set of operations) is atomic, linearizable, indivisible or uninterruptible if it appears to the rest of the system to occur instantaneously. Atomicity is a guarantee of isolation from concurrent processes. Additionally, atomic operations commonly have a succeed-or-fail definition — they either successfully change the state of the system, or have no apparent effect.

I have seen the word transaction used more often for databases and operation in programming, especially in kernel-level programming.

like image 27
Jean Avatar answered Oct 17 '22 16:10

Jean


In a statement: an atomic transaction is the smallest set of operations to perform the required steps. Either all of those required operations happen(successfully) or the atomic transaction fails.

An atomic operation usually has nothing in common with transactions. To my knowledge this comes from hardware programming, where an set of operations (or one) happen to get solved instantly.

like image 6
Najzero Avatar answered Oct 17 '22 17:10

Najzero