jdk的配置文件中,使用securerandom.source设置了熵源:

cat /usr/java/jdk1.8.0_121/jre/lib/security/java.security

securerandom.source=file:/dev/random

可以看到默认值是:/dev/random
所以程序启动后SecureRandom类会读取/dev/random以获取随机序列,这是一个同步操作。当熵池(entropy pool) 中没有足够的熵时,读取/dev/random就会造成阻塞,直到收集到了足够的熵,程序才会继续往下进行。
(关于什么是/dev/random,可以查看 wiki的介绍


解决方法是修改成非阻塞的熵源/dev/urandom
可以修改java.security文件中的securerandom.source值,也可以使用参数java.security.egd

java -jar app.jar -Djava.security.egd=file:/dev/./urandom

至于为什么是/dev/./urandom,而不是/dev/urandom,这源于java的一个bug。大意是/dev/urandom在某些情况下可能还是最终会转换成调用/dev/random。所以为了保险起见,还是使用/dev/./urandom吧!

相关文章:

  • 2021-12-08
  • 2021-09-21
  • 2022-02-17
  • 2021-11-15
  • 2021-12-02
  • 2022-12-23
  • 2022-02-07
  • 2021-08-30
猜你喜欢
  • 2022-12-23
  • 2021-08-31
  • 2022-02-03
  • 2021-11-08
  • 2021-11-23
  • 2021-09-18
  • 2021-12-26
相关资源
相似解决方案