/dev/random と /dev/urandom の違い
スポンサーリンク
/dev/random は、 Unix 系オペレーティングシステムのスペシャルファイルの1つです。擬似乱数生成機として使われます。
/dev/random をはじめて実装したのは、Linuxのようです。
/dev/random は、エントロピープールにノイズのビット数を保持しています。/dev/randomを読み出すと、エントロピープールからノイズビット数予測から乱数のバイト列を返します。乱数をたくさん読み出すとエントロピープールが空にになります。この状態で/dev/randomを読み出そうとするとブロックされ、ノイズが集まるまで待たされます。
ブロックする目的は、真の乱数生成機として機能することで、暗号鍵の生成などにも安全に利用できることを意図しています。
/dev/random に対して、 /dev/urandom があります。 urandom は unlocked random source の意味で、ノンブロッキングなデバイスファイルとして動作します。
エントロピープールを再利用することで、擬似乱数的な乱数ビット列を生成できます。
/dev/random とは異なり、安全性を要求されない条件で、高速に動作させたいときに urandom を使います。
FreeBSDなら /usr/src/sys/dev/random/ このあたりにデバイスのソースがあります。
FreeBSD の /dev/random では Yarrow アルゴリズムを使っています。
Yarrow アルゴリズムは、暗号的セキュア擬似乱数生成器です。
ソースはここらへん。
/usr/src/sys/dev/random/yarrow.c
FreeBSD では /dev/urandom は random へのシンボリックリンクです。
/dev/random をはじめて実装したのは、Linuxのようです。
/dev/random は、エントロピープールにノイズのビット数を保持しています。/dev/randomを読み出すと、エントロピープールからノイズビット数予測から乱数のバイト列を返します。乱数をたくさん読み出すとエントロピープールが空にになります。この状態で/dev/randomを読み出そうとするとブロックされ、ノイズが集まるまで待たされます。
ブロックする目的は、真の乱数生成機として機能することで、暗号鍵の生成などにも安全に利用できることを意図しています。
/dev/random に対して、 /dev/urandom があります。 urandom は unlocked random source の意味で、ノンブロッキングなデバイスファイルとして動作します。
エントロピープールを再利用することで、擬似乱数的な乱数ビット列を生成できます。
/dev/random とは異なり、安全性を要求されない条件で、高速に動作させたいときに urandom を使います。
FreeBSDなら /usr/src/sys/dev/random/ このあたりにデバイスのソースがあります。
FreeBSD の /dev/random では Yarrow アルゴリズムを使っています。
Yarrow アルゴリズムは、暗号的セキュア擬似乱数生成器です。
ソースはここらへん。
/usr/src/sys/dev/random/yarrow.c
FreeBSD では /dev/urandom は random へのシンボリックリンクです。
% ls -ls /dev/*random* 0 crw-rw-rw- 1 root wheel 0, 28 5 6 2010 /dev/random 0 lrwxr-xr-x 1 root wheel 6 5 5 2010 /dev/urandom@ -> random
スポンサーリンク
スポンサーリンク
いつもシェア、ありがとうございます!
もっと情報を探しませんか?
関連記事
最近の記事
- パナソニック ジェットウォッシャードルツ EW-DJ61-Wのホースの修理
- LinuxセキュリティモジュールIntegrity Policy Enforcement
- アマゾンのEcho Show 5を買ったのでレビューします
- アマゾンのサイバーマンデーはAlexa Echo Show 5が安い
- Android スマートフォン OnePlus 7T と OnePlus 7の違い
- Android スマートフォン OnePlus 7 をAndroid10にアップデートしてみた
- クレジットカードのバーチャルカードの比較のまとめ
- 活動量計 Xiaomi Mi Band 4を買ってみたのでレビュー
- Android スマートフォン OnePlus 7 のレビュー
- AliExpressでスマートフォンを買い物してみた
- パソコンのホコリ対策 レンジフードフィルターと養生テープ
- 80PLUS GOLDのPC電源ユニットAntec NeoEco 750 Goldのレビュー
- イギリスの付加価値税 VAT は払い戻しを受けられる
- イギリスのロンドンでスーツケースなど荷物を預けられる場所は
- イギリスのロンドンで地下鉄やバスに乗るならオイスターカードを使おう
- イギリスのヒースロー空港からロンドン市内への行き方
- 航空便でほかの航空会社に乗り継ぎがある場合のオンラインチェックイン
- SFC会員がANA便ではなくベトナム航空のコードシェアを試して解ったこと
- ベトナムの入国審査でeチケットの掲示が必要だった話
- シアトルの交通ICカードはオルカカード(Orca)です
人気のページ
- Windows7 IME 辞書ツールで単語の登録に失敗しました
- C言語 popen()でコマンドを実行して出力を読み込む
- Windows7で休止状態にする方法
- CentOS MySQLの起動、停止、再起動
- loggerコマンドでsyslogにエラーを出力する方法
- パソコンパーツの買取をしてくれる店のまとめ
- Java Mapの使い方 get(),put(),remove(),size(),clear()
- 楽天のRポイントカードを作ってみた
- iPhone 5 から iPhone 6 に乗り換えたのでレビュー
- netstatコマンドのステータスの意味
スポンサーリンク
過去ログ
2020 : 01 02 03 04 05 06 07 08 09 10 11 122019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12