/dev/random 和/dev/urandom


内核内部有一个随机数发生器,当内核用户希望使用随机序列时,随机数发生器提供API,如get_random_bytes().对于用户模式的程序,提供两个字符接口/dev/random 和/dev/urandom,它们都属于虚拟设备。从/dev/random获取的随机数的随机性要高于dev/urandom。这与它们自身随机数产生原理有关。

/dev/random并非使用公式产生随机数,而是采用收集“环境噪声”(如中断、键盘等)维持一个混乱池以产生随机流。内核源码random.c中add_timer_randomness()、add_input_randomness()、 add_interrupt_randomness()、add_disk_randomness()等函数的作用就是根据当前的“环境噪声”向混乱池补充新的随机流。持续的“环境噪声”会向混乱池产生持续的随机流,否则,混乱池将最终被完全消耗,换而言之,/dev/random会引起阻塞。可以用od、if命令验证该结论,如od -x /dev/random。

/dev/urandom产生原理不同于/dev/random,它会连续不间断的输出伪随机流。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值