AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 693160
Accepted
John Phillips
John Phillips
Asked: 2022-03-07 12:07:38 +0800 CST2022-03-07 12:07:38 +0800 CST 2022-03-07 12:07:38 +0800 CST

如何强制 /dev/random 阻止?

  • 772

对于密码学课程,我正在尝试耗尽 Linux 中的熵池(例如 make /proc/sys/kernel/random/entropy_availgo to 0 并阻止从 读取的命令/dev/random),但我无法实现。我应该从/dev/random阻止读取。如果我执行这两个命令:

watch -n 0.5 cat /proc/sys/kernel/random/entropy_avail

观察熵,然后:

od -d /dev/random

为了转储随机池,watch命令中的值在 3700 和 3900 之间徘徊,并且在我运行此命令时只获得和损失一点点。我让这两个命令运行了大约三分钟,而entropy_avail. 那段时间我没有在电脑上做太多事情。通过谷歌搜索,我发现硬件随机数生成器可能非常好,以至于熵不会下降,但如果我这样做:

cat /sys/devices/virtual/misc/hw_random/rng_available

我什么也没看到,我只是得到一个空白行。所以我有几个问题:

  1. 是什么很好地补充了我的熵,我怎样才能找到随机性的具体来源?
  2. 有什么方法可以暂时禁用随机源,以便我可以强制这种阻塞发生?
linux-kernel random
  • 3 3 个回答
  • 3355 Views

3 个回答

  • Voted
  1. Best Answer
    frostschutz
    2022-03-07T13:12:10+08:002022-03-07T13:12:10+08:00

    围绕 Linux 随机设备的开发数量惊人。缓慢的阻塞/dev/random消失了,取而代之的/dev/random是永远不会耗尽数据的快速。

    您将不得不回到过去,例如在 linux 4.8(引入了更快的 crng 算法)或可能的 linux 5.6(引入了抖动熵生成)之前。

    无法在当前内核中恢复原始行为。


    如果您在旧版本的 Linux 中看到此问题,除了 hwrng,您可能正在使用haveged或 rng-toolsrngd或类似的用户空间熵提供程序。

    一些发行版默认安装这些以避免在等待一些随机位时挂起,在这种情况下,您可以卸载或禁用它们,或者从没有其他进程运行的 initrd / busybox shell 中尝试它。

    如果问题仍然存在,您可能只是有一个非常嘈杂的硬件,内核不断地从该硬件中自然地收集熵。

    • 32
  2. fuzzydrawrings
    2022-03-07T13:29:09+08:002022-03-07T13:29:09+08:00

    是什么很好地补充了我的熵,我怎样才能找到随机性的具体来源?

    从内核 5.6 开始,/dev/random从内核的 CRNG 中获取随机性,该 CRNG 在引导期间初始化并且不会阻塞。

    请参阅“删除 Linux /dev/random 阻塞池”。

    有什么方法可以暂时禁用随机源,以便我可以强制这种阻塞发生?

    我认为您必须使用 5.6 之前的内核。

    • 21
  3. CR.
    2022-03-07T13:26:14+08:002022-03-07T13:26:14+08:00

    这可能取决于您的硬件,如果它使用 CPU 功能,那么它可能是无穷无尽的。其他硬件则不然。

    但是,您可以在引导时尝试内核选项。 random.trust_cpu=off

    • 5

相关问题

  • 如何让我的帧缓冲控制台工作?

  • 阻止挂载系统调用

  • 为什么无线工具版本 30 成为永久测试版?

  • 程序堆栈大小

  • 哪些 802.11ac(或更高版本)WiFi 加密狗适用于 Linux 4.13 内核

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve