加快 SecureRandom 性能的策略
SecureRandom 是 Java 中加密鲁棒随机数生成的基石,可能会造成严重的性能瓶颈。在 Linux 平台上,由于系统积累了足够的熵,它对 /dev/random 的依赖可能会导致长时间阻塞。为了减轻这种性能拖累,可以采用多种策略。
利用更快的 /dev/urandom 替代方案
在 Linux 上,用户可以利用安全性稍差但显着的方法/dev/urandom 作为 /dev/random 的替代品更快。这可以通过设置 java.security.egd 系统属性来实现,如下所示:
-Djava.security.egd=file:/dev/urandom
Java 5 及更高版本的解决方法
不幸的是,此方法不兼容由于已知错误 (Java Bug 6202721),Java 5 及后续版本中出现此错误。要避免此问题,可以应用以下解决方法:
-Djava.security.egd=file:/dev/./urandom
(请注意包含额外的 /./)
替代解决方案
解决性能难题的另一个潜在解决方案是利用 Uncommon Maths,这是一种开源软件提供高性能随机数生成器的库。虽然它的实现可能与 SecureRandom 不同,但作为一种可行的替代方案值得探索。
JDK 6 中的进展
关于 JDK 6 中解决的性能问题,相互冲突的信息存在。一些消息来源表明该问题已得到解决,而另一些消息来源则表明情况并非如此。可能需要进一步研究来确定 JDK 6 的当前状态。
以上是如何提高 Java 中 SecureRandom 的性能?的详细内容。更多信息请关注PHP中文网其他相关文章!