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
    • 最新
    • 标签
主页 / server / 问题 / 471412
Accepted
stormdrain
stormdrain
Asked: 2013-01-23 07:36:32 +0800 CST2013-01-23 07:36:32 +0800 CST 2013-01-23 07:36:32 +0800 CST

gpg --gen-key 在 centos 6 上获得足够的熵时挂起

  • 772

尝试为服务器生成密钥。

gpg --gen-key

我们需要生成很多随机字节。在素数生成期间执行一些其他操作(在键盘上键入、移动鼠标​​、使用磁盘)是个好主意;这使随机数生成器有更好的机会获得足够的熵。

它只是挂在那里。

还有一个错误:

无法连接到“/root/.gnupg/S.gpg-agent”:没有这样的文件或目录

这似乎在之后消失了:

gpg-agent --daemon
GPG_AGENT_INFO=/tmp/gpg-4c5hyT/S.gpg-agent:1397:1; 导出 GPG_AGENT_INFO;

#GPG_AGENT_INFO=/tmp/gpg-4c5hyT/S.gpg-agent:1397:1; export GPG_AGENT_INFO;
gpg --gen-key
...

但同样,它停留在“......获得足够的熵”。

没有“++++++++++++++++++++++++++++++++++++++++++++”从论坛帖子看起来应该在生成密钥时预期。

我试过重新安装软件包,但似乎一切都取决于 gpg。

我读过其他人在 centos 6 上也遇到过这个问题(而 centos 5 工作正常)。

中没有什么了不起的/var/log/*。

关于从这里去哪里的任何想法?

谢谢。

centos6
  • 9 9 个回答
  • 53629 Views

9 个回答

  • Voted
  1. Best Answer
    John
    2013-01-23T07:56:44+08:002013-01-23T07:56:44+08:00

    当gpg --gen-key命令像这样挂起时,登录到另一个shell并执行以下命令:

    dd if=/dev/sda of=/dev/zero
    

    (此命令基本上从您的硬盘驱动器读取并丢弃输出,因为写入/dev/zero不会执行任何操作。)

    几秒/分钟后,密钥生成命令应该完成。

    • 66
  2. golja
    2013-01-23T20:07:50+08:002013-01-23T20:07:50+08:00

    对于更可靠的解决方案,您可以安装随机数生成器相关的实用程序,这将确保您始终有足够的随机字节。

    yum install rng-tools
    

    然后编辑/etc/sysconfig/rngd并添加EXTRAOPTIONS="-r /dev/random"

    启动服务

     service rngd start
    

    瞧,你从此过上了幸福的生活:)

    • 26
  3. rhinoceros.xn
    2018-06-08T06:34:38+08:002018-06-08T06:34:38+08:00

    https://gist.github.com/franciscocpg/1575d286548034113884c3185ca88681

    打开一个 ssh 会话 sudo apt-get install rng-tools 在另一个 SSH 窗口中打开 gpg --gen--key 返回到您的第一个 SSH 会话并运行 sudo rngd -r /dev/urandom 让这个运行直到 gpg 生成您的密钥!

    然后你可以杀死rngd sudo kill -9 $(pidof rngd)

    • 12
  4. Soham Chakraborty
    2013-01-24T09:10:32+08:002013-01-24T09:10:32+08:00

    之前给出的两条评论都很好。但这只是我的 2 美分。

    RHEL/centos 6 和 entropy 的问题在于它们是 tickless 内核。因此,这些内核本身并不能产生足够的熵。您必须连接一些键盘,甚至必须移动一些鼠标,或者如上所述使用 dd。

    rngd 守护进程很棒,大多数商业实体都在使用它。

    然而,我见过的最好的方法是使用专用的 TPM 设备。它们是非常昂贵的小型硬件。您放置它们,rngd 使用来自硬件源的随机真熵。据我所知,富士通有一些不错的TPM设备。

    是的,这三种方法几乎涵盖了熵部分。

    • 11
  5. Dave Brunkow
    2018-01-18T09:03:41+08:002018-01-18T09:03:41+08:00

    扭曲其他响应,但至少有一个衬里而不是根。

    ((find / | xargs file) &> /dev/null &); gpg2 --gen-key --batch --passphrase-file output-key.txt key-gen-options.txt
    

    密钥生成选项包含

    Key-Type: 1
    Key-Length: 2048
    Subkey-Type: 1
    Subkey-Length: 2048
    Name-Real: myuser
    Name-Email: [email protected]
    Expire-Date: 0
    

    Output-key.txt 包含我的超级密钥。

    • 7
  6. Marjo Mercado
    2014-10-11T12:46:31+08:002014-10-11T12:46:31+08:00

    EXTRAOPTIONS="-r /dev/urandom" 为我工作而不是 EXTRAOPTIONS="-r /dev/random"

    • 4
  7. wisbucky
    2019-07-13T15:32:04+08:002019-07-13T15:32:04+08:00

    我已经尝试了所有的解决方案,发现haveged即使在其他解决方案不起作用时效果最好(尤其是在没有太多用户输入或活动的无头服务器上)。

    yum install haveged

    apt install haveged

    它启动haveged将保持/dev/random充满熵的守护进程服务。--key-gen应在不到一分钟内完成。

    您可以通过运行来验证cat /dev/random。通常,它会很快耗尽熵并暂停。这就是--key-gen挂起的原因。但安装后haveged,cat /dev/random应该持续提供输出。

    • 4
  8. user246890
    2017-08-09T03:57:45+08:002017-08-09T03:57:45+08:00

    我是怎么做到的:

    1. pacman -S community/rng-tools
    2. vim /etc/conf.d/rngd添加RNGD_OPTS="-r /dev/urandom"
    3. systemctl enable --now rngd
    4. gpg-agent --daemon
    5. gpg --full-gen-key

    即使在$GNUPGHOME设置为指向自定义目录时也能正常工作。

    • 2
  9. Todd Tope
    2021-06-30T09:52:40+08:002021-06-30T09:52:40+08:00

    切换到 gpg2 对我有用。

    由于权限问题,其他解决方案都没有。

    • 0

相关问题

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve