Hacker News new | past | comments | ask | show | jobs | submit login

I'm coming from a background in massively parallel computing and financial services, both of which are heavy on security. Nonetheless, and even though I have been running cryptographically active instances on Amazon and Rackspace for a long time, I had honestly never thought about the RNG source on VMs.

That is my own failure, of course. I wonder, though, whether everyone else knew about the VM RNG issue, or if only I had missed the memo. If the majority of poll respondents have never thought about the problem at all, perhaps I should start an awareness campaign on wikis and forums.




You did not miss the memo. Crypto on virtualized cloud platforms isn't trustworthy. But it's a grade of untrustworthy several steps higher than "exploitable SQL injection", so people don't think about it, talk about it, or take it seriously.

The poll, though, is unnecessary and I flagged it.

Meanwhile, you brought up:

Robert Brown's dieharder: http://www.phy.duke.edu/~rgb/General/dieharder.php

NIST Statistical Test Suite: http://csrc.nist.gov/groups/ST/toolkit/rng/index.html

Fourmilab's ENT: http://www.fourmilab.ch/random/

You noted that people could run these on their CSPRNGs to check randomness. No, they can't. These are all useful tools indeed; pentesters use them to check cookies and crypto tokens. But they can only tell you whether bits are correlated. It is very easy for an uncorrelated stream of bits to be terribly insecure: they simply have to be seeded from the same source.

It is not a good idea to suggest people test their RNGs with things like "ent". In "ent", Ruby's insecure rand() can appear competitive with /dev/random.

There's also the obvious confounding issue with testing an entropy pool by depleting it.


It is very easy for an uncorrelated stream of bits to be terribly insecure: they simply have to be seeded from the same source.

Case in point: The b0rked Debian OpenSSL RNG would certainly pass any statistical tests. But it still turned out to have only something on the order of 32767 unique sequences, i.e., 15 bits of entropy.


Hence the caveat: "and hope/trust that the entropy you observe is unique, not copied to any other instances".

I suppose it would take a centralized web service to detect correlated unrandomness between servers. I am not personally willing to implement such a service right now.


Even if entropy isn't shared, you can't really test a CSPRNG by feeding it through "ent".




Consider applying for YC's Spring batch! Applications are open till Feb 11.

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: