RAMCloud: The Idea of Storing All Data in RAM
Researchers at Stanford University have an idea how to overcome latency and performance bottlenecks of hard drive and solid state disk-based storage systems.
According to a recently published paper, they believe that a RAM-based cloud system with about 1000 servers and a total RAM capacity of 64 TB can be built for about $4 million and is feasible today.
Compared to a disk-based system, a RAMCloud could have a 100-1000x lower latency than disk-based systems and 100-1000x greater throughput, the researchers said. The system would use replication and backup techniques to overcome the problem of volatility and data loss if the power supply is interrupted. The approach would provide enough performance for cloud systems to solve scalability issues for web applications, enable a "a new class of data-intensive applications" due to the extremely low latency of RAM and provide a growth path for small applications to grow into a large application on demand.
The estimate is that latencies of only 5 to 10 microseconds should be achievable by a measured RAMCloud system, which is about 1000x faster than the 5 - 10 milliseconds that is provided by disk-based systems for data that is accessed over a network. The researchers estimate that a single multi-core RAM server could support at least 1,000,000 small requests per second, while disk based systems are typically maxed out at 1000 to 10,000 requests.
Cost is the barrier for a broad use of such RAMClouds. However, the scientists noted that "the cost of DRAM today is roughly the same as the cost of disk 10 years ago ($ 10-30/GB)", which, of course, does not help much considering the massive storage space requirements today.
- MSI Offering iOS App for Overclocking GPU
- Kingston Releases SSDNow V200 Series SSDs
- Skyrim Developer Says PC Development is a Headache
- EA President Confirms There Will Be a Battlefield 4
- ARM Reveals 8-Core GPU For Superphones
- Steam's Database Hacked, Info Possibly Stolen
- Swiftech Releases H2O-x20 Edge HD Liquid Cooling Kits
- Happy Birthday Firefox, You're Now 7 Years Old!
- Nvidia Releases New Battlefield 3, Skyrim Beta Drivers
- Estonian Clickjacking Ring Totally Busted
- OCZ reveals the PC Power & Cooling Silencer Mk III Series PSUs
- Mathematicians Calculate 10 Trillion Digits of Pi With Xeons
- Star Trek Online Going Free-to-Play in January 2012
- The $79 Kindle Costs Amazon $84 to Make
- XFX adds 1,000+ Watt PSUs to Its ProSeries
- NEC Has a Huge 52-inch Tablet On Wheels
- 3 Ways That Windows is Smarter With Power
- Winner of the AMD Bulldozer CyberPower PC







No really? This can be done for a consumer, as well. Imagine having your entire OS in the RAM? An X79 board has what, 8 RAM slots? Throw 8GB into each one and you get 64GB, that's more than enough for a full Windows installation and some programs. It will be blazing fast.
i really don't see an use for this type of things...although it will be nice if you are a Minecraft maniac...but in real life task even more than 8gb for now is very unnecessary and stupidly excessive.
And how are you planning to get around the volatility problem on your home rig sir amk-aka-Pantom?
Sounds awesome - until the power goes out.
;(
i really don't see an use for this type of things...although it will be nice if you are a Minecraft maniac...but in real life task even more than 8gb for now is very unnecessary and stupidly excessive.
Prices keep going down. RAM is dirt cheap; 8GB costs $50 (2x4GB), the new 8GB chips are costly but prices WILL fall, and having your stuff in the RAM is awesome. And for servers, it's even better. Did you read this:
That is, bye-bye to DDOS.
Sounds awesome - until the power goes out.;(
UPS for you
And how are you planning to get around the volatility problem on your home rig sir amk-aka-Phantom?
Elaborate, please!
i really don't see an use for this type of things...although it will be nice if you are a Minecraft maniac...but in real life task even more than 8gb for now is very unnecessary and stupidly excessive.
more than 8GB is recommended if you do some CS5.5 or 3D uses... 8GB is need for gaming system... Your all about the games instead of what's out there in the internet that you needa experience...
And how are you planning to get around the volatility problem on your home rig sir amk-aka-Pantom?
There is non-volatile ram in development. Not sure if it will ever become a real product, but it's there.
amk-aka-Phantom - after you use all that 64gb of ram for your os and some programs, what ram do you have left to actually run them? sheesh
ok so what happens if the computer turns off? screw all of you!!! your information is gone lol
There is non-volatile ram in development. Not sure if it will ever become a real product, but it's there.
I thought SSDs use non-volatile NAND RAM? or is that NAND flash? :\
Why do they call it a "could" system? Isn't this just a ram-based server? Cloud is like, for storing data and things right? "Run your shitz of the cloud". I can't see the point of it for cloud storage, would be too expensive. What's the point of the super-low latency if your ping to the RamCloud will be 200ms? A movie streams a ms late, big deal...
If it's used for regular server hosting (like game servers, etc) then i can see the point, because computation time would reduce.
more than 8GB is recommended if you do some CS5.5 or 3D uses... 8GB is need for gaming system... Your all about the games instead of what's out there in the internet that you needa experience...
Also nice if you have a couple VMs running. My board is maxed out at 16.
BTW does anyone else notice a CPU usage spike when you scroll from the article to the comments? Happens somewhere at the end of the article...been noticing this for a while.
Use chrome, 32-bit, 3.2GB RAM and a Core 2 Quad. Tried on a C2D laptop and happens there too, had used chrome again.
EDIT: Just tried with IE, spike happens but you cant notice it. Chrome actually stutters a bit...
I thought SSDs use non-volatile NAND RAM? or is that NAND flash? :\
Why do they call it a "could" system? Isn't this just a ram-based server? Cloud is like, for storing data and things right? "Run your shitz of the cloud". I can't see the point of it for cloud storage, would be too expensive. What's the point of the super-low latency if your ping to the RamCloud will be 200ms? A movie streams a ms late, big deal...
If it's used for regular server hosting (like game servers, etc) then i can see the point, because computation time would reduce.
yeah if you are the ONLY one using it then the timing difference is almost nothing compared to the ping, but if you have hundreds of thousands of users accessing the data HDD's and even SSD's wouldn't be able to keep up, that is where the Ram Cloud would come in
amk-aka-Phantom - after you use all that 64gb of ram for your os and some programs, what ram do you have left to actually run them? sheesh
About 29GB. My current OS/programs partition takes 35GB. U mad?
yeah if you are the ONLY one using it then the timing difference is almost nothing compared to the ping, but if you have hundreds of thousands of users accessing the data HDD's and even SSD's wouldn't be able to keep up, that is where the Ram Cloud would come in
Ah...didn't think of that!
It's called a RAM-drive, and this is nothing new. You can do this on any desktop machine if you want, it's just usually not worth it due to power interruptions. Still fun nonetheless.
You lost me at cloud
Not sure if the researchers have taken into consideration the added cost from having to use only buffered ECC RAM. The unbuffered non-ECC RAM some of the commenters here are referring to is considered volatile for more than just what happens when the power turns off. After some time the data stored in this RAM becomes corrupted and would no longer be the same data. Ever wonder why some programs after being open and running for several days can sometimes start to act funny after a while?
For the past 20 years or so OS's have used redundancy to help with this issue via the swap file on the HDD. Using buffered ECC RAM can eliminate about 99% of this problem, but can cost 2-3 times as much in some cases. Although, I suppose you could offset the cost by using twice as much "regular" RAM and using half for redundancy. Still, the best option would be to store the data on a typical storage device and have a newer better buffering system which keeps and accurate and updated copy in the RAM "cloud" which could keep the data integrity in check. This way there would only be the older latency issue initially when the data is being uploaded or altered, or when it needs to be rebuffered because of corruption. Plus that thing about the power going out would be a non issue.
This makes zero sense for a home user. But makes a lot of sense in some situations. Master server that writes results to disk, with many slaves that only have ram for instance.
I can see this ram cloud service now . "Tech support: how can i help you", "you: all my files are missing", "tech: ya we had a power failure, sorry everything is stored in ram, all data is gone", "you: excuse me?"
If you went for a massive RAM drive like this why wouldn't you couple it with tiers of other storrage? SSD's and a large pool of harddrives? I don't know the optimal combination, having some parts work as cache for others.
My second computer was a Leading Edge 286 with a VGA color monitor, about $2 grand. I don't remember the specs except for the gigantic 65MB HD. My impossible dream was having a 640MB HD and a 640MB ram drive and leave the machine turned on all the time and keep the hard drive mirrored on the Ram drive. I still miss the Leading Edge clicker keyboard.
there are ways to power ram, to get over the volatile problem, expensive as hell last time i looked into them though.
i really don't see an use for this type of things...although it will be nice if you are a Minecraft maniac...but in real life task even more than 8gb for now is very unnecessary and stupidly excessive.
You don't even understand what this article is about and I don't care to enlighten you, just one clue it's not about consumer level use.
I thought SSDs use non-volatile NAND RAM? or is that NAND flash? :\Why do they call it a "could" system? Isn't this just a ram-based server? Cloud is like, for storing data and things right? "Run your shitz of the cloud". I can't see the point of it for cloud storage, would be too expensive. What's the point of the super-low latency if your ping to the RamCloud will be 200ms? A movie streams a ms late, big deal...If it's used for regular server hosting (like game servers, etc) then i can see the point, because computation time would reduce.
NAND RAM is much slower than DRAM and can wear out after certain number of writes and erase cycles.
Yes someone's ping could be 200 due to internet connection, but usage of RAM for storage could allow that 100-1000X people have 200ms ping where HDD/SSD allows for X people to have.
Not sure if the researchers have taken into consideration the added cost from having to use only buffered ECC RAM. The unbuffered non-ECC RAM some of the commenters here are referring to is considered volatile for more than just what happens when the power turns off. After some time the data stored in this RAM becomes corrupted and would no longer be the same data. Ever wonder why some programs after being open and running for several days can sometimes start to act funny after a while?For the past 20 years or so OS's have used redundancy to help with this issue via the swap file on the HDD. Using buffered ECC RAM can eliminate about 99% of this problem, but can cost 2-3 times as much in some cases. Although, I suppose you could offset the cost by using twice as much "regular" RAM and using half for redundancy. Still, the best option would be to store the data on a typical storage device and have a newer better buffering system which keeps and accurate and updated copy in the RAM "cloud" which could keep the data integrity in check. This way there would only be the older latency issue initially when the data is being uploaded or altered, or when it needs to be rebuffered because of corruption. Plus that thing about the power going out would be a non issue.
Or you can, as researches did, use regular HDDs for backup and redundancy.
BTW does anyone else notice a CPU usage spike when you scroll from the article to the comments? Happens somewhere at the end of the article...been noticing this for a while.Use chrome, 32-bit, 3.2GB RAM and a Core 2 Quad. Tried on a C2D laptop and happens there too, had used chrome again.EDIT: Just tried with IE, spike happens but you cant notice it. Chrome actually stutters a bit...
Tested it out.. you're right.
Sounds awesome - until the power goes out.;(
You are 100% correct. No UPS lasts forever. Even with generators all it takes is a single datacenter to have an outage just a little greater than their backup power. Just ask RIM.
I'ts a horrible Idea if you not constantly replicating to disks, wich will probably not keep up.
Purely in-memory datastores, like memcached and redis, have been around for awhile. MemcacheDB and RedisCluster (still in progress) are projects which manage large clusters running these services. Redis and memcached were both benchmarked handling in excess of 100k reads/writes per second on consumer grade laptops a few years ago. Redis can even snapshot to disk fairly frequently so that it isn't as volatile.
It's great to see more people talking about this as a viable technology, but these researchers are a few years behind the times. The algorithms for making large clusters handle failing nodes are in wide use for disk based storage systems, the software for memory-only storage services are in common use, combinations there of, as mentioned above, are already being built and have been talked about for years.
BTW does anyone else notice a CPU usage spike when you scroll from the article to the comments? Happens somewhere at the end of the article...been noticing this for a while.Use chrome, 32-bit, 3.2GB RAM and a Core 2 Quad. Tried on a C2D laptop and happens there too, had used chrome again.EDIT: Just tried with IE, spike happens but you cant notice it. Chrome actually stutters a bit...
Nope. Running the latest version of Chrome, an i5 750, 8GB RAM, Win7 64-bit, and a geforce 550ti. I looked while scrolling down and the CPU usage was only at 3-5%.
Gawd, this is 'tarded. Smart server applications cache everything they need in memory anyways this is like something a 14 y/o would think of, I'd hate to think of the "research" that went into this idea.