- System Prevalence
-
System prevalence is a simple software architectural pattern that combines system images (snapshots) and transaction journaling to provide speed, performance scalability, transparent persistence and transparent live mirroring of computer system state.
In a prevalent system, state is kept in memory in native format, rather than being written to an RDBMS or other data storage system. All transactions are journaled and System images are regularly saved to disk.
System images and transaction journals can be stored in language-specific serialization format for speed or in XML format for cross-language portability.
The first usage of the term and generic, publicly-available implementation of a system prevalence layer was Prevayler, written for Java by Klaus Wuestefeld in 2001.[1]
Contents
Advantages
Simply keeping system state in RAM in its normal, natural, language-specific format is orders of magnitude faster and more programmer-friendly than the multiple conversions that are needed when it is stored and retrieved from a DBMS. As an example, Martin Fowler describes "The LMAX Architecture" [2] with a transaction-journal and system-image (snapshot) based business system at its core, which can process 6 million transactions per second on a single thread.
Requirement
A prevalent system needs enough memory to hold its entire state in RAM (the "prevalent hypothesis"). Prevalence advocates claim this is continuously alleviated by decreasing RAM prices, and the fact that many business databases are small enough already to fit in memory.
Programmers need skill in working with business state natively in RAM, rather than using explicit API calls for storage and queries for retrieval.
The system's events must be capturable for journaling.
Implementations
Java
.NET
- Bamboo.Prevalence
- #liveDB
- DevMagicFake
Python
Ruby
Common Lisp
Perl
- Perlvayler
Smalltalk
Javascript
References
- ^ Klaus Wuestefeld (2001-12-23). "Object Prevalence". Advogato. http://www.advogato.org/article/398.html. Retrieved 2008-04-02.
- ^ Martin Fowler (2011-07-12). "The LMAX Architecture". http://martinfowler.com/articles/lmax.html#KeepingItAllInMemory. Retrieved 2011-07-28. "A thread that will process 6 million orders per second using commodity hardware."
External links
- "An Introduction to Object Prevalence", by Carlos Villela for IBM Developerworks. [1]
- "Prevalence: Transparent, Fault-Tolerant Object Persistence", by Jim Paterson for O'Reilly's OnJava.com [2]
- List of Prevalent System layer implementations for various languages [3]
- "Object Prevalence": Original Article by Klaus Wuestefeld published in 2001 on Advogato. [4]
See also
Categories:- Persistence
- Computer science stubs
Wikimedia Foundation. 2010.