Big memory
Big memory is a software and hardware approach that facilitates storing/retrieval/processing of large data sets (terabytes and higher). The term is akin to big data and in some instances is a form of big data processing architecture implemented in memory rather than in disks/storage. Different caches are one of the usage of the big memory.
The computer memory, namely RAM, works orders of magnitude faster than hard drives or even solid state drives, which is usually due to higher raw data throughput from tighter coupling of CPU and RAM chips (wider bus, CPU and RAM are usually installed on the same motherboard).
Locality of reference is another important characteristic for caches and fast access.
The price of the computer memory chips has significantly declined since the late 2000s, as of 2015 it is affordable to have 256 gigabytes of RAM on a server. [1]
Currently, not many vendors have solid software big memory solutions while there are plentiful hardware options (i.e. cheap RAM planks). Terracotta has developed a "in-memory data management suite" [2]
The contemporary software platforms that are based on a garbage collected models, such as .NET CLR , JAVA and others can not usually store hundreds of millions resident objects (object staying in RAM for minutes+ and get promoted to older generations) directly as this results in GC stalls that significantly affect the performance.[3] [4] As of 2015 there are still no efficient simple GC solutions that would have allowed to store 16Gb+ object in a language-native-heaps so there are hybrid approaches emerging for memory-hungry apps in the managed environments.
NFX Unistack framework provides a concept of a large managed memory 'Pile' on a .NET CLR platform based on pre-allocated large byte[] that do not slow GC down.[5] The solution allows to easily store 300,000,000 business objects on a machine with 64 Gb RAM while allowing for millions object put/get transactions a second. The solution was purposely provided for processing Big Memory data sets without going to disk/network.[6] [7] [8] [9]
References
- ↑ 128 Gb ram chip on NewEgg - http://www.newegg.com/Product/Product.aspx?Item=9SIA7S634M7975
- ↑ Terracotta, Inc. - http://terracotta.org/products/bigmemorymax
- ↑ Understanding GC pauses in JVM, HotSpot's minor GC. - http://blog.ragozin.info/2011/06/understanding-gc-pauses-in-jvm-hotspots.html
- ↑ Long GC pauses in application - http://stackoverflow.com/questions/15696585/long-gc-pauses-in-application
- ↑ NFX GitHub Inc. - https://github.com/aumcode/nfx
- ↑ About Managed Object Pile - https://www.youtube.com/watch?v=WFA1XirINB0
- ↑ .NET Heap with hundreds of millions of objects - https://www.youtube.com/watch?v=Dz_7hukyejQ
- ↑ Big Memory in .NET 1 - http://www.infoq.com/articles/Big-Memory-Part-1
- ↑ Big Memory in .NET 2 - http://www.infoq.com/articles/Big-Memory-Part-2
External links
|
|
|