解决 Creation of SecureRandom instance for session ID generation 耗时太久问题

本文探讨了SpringBoot结合SpringSecurity在用户首次登录时接口响应缓慢的问题,深入分析了Tomcat内部加载配置导致的延迟原因,特别是SecureRandom实例生成过程中的SHA1PRNG算法消耗时间过长,并提供了修改JDK配置文件的具体步骤来解决此问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SpringBoot +SpringSecurity项目重新启动的时候,内置tomcat重新加载配置,用户第一次登陆的时候,接口特别慢,甚至超时。

日志显示一条WARN级别日志值得注意:org.apache.catalina.util.SessionIdGeneratorBase - Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [19,665] milliseconds.

问题说明

Tomcat 7/8都使用org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom类产生安全随机类SecureRandom的实例作为会话ID。

SHA1PRNG是基于SHA-1算法的伪随机数生成器,用来生成保密性较强的伪随机数。

在SHA1PRNG中,有一个种子产生器,它根据配置执行各种操作。

1)如果 java.security.egd 属性或 securerandom.source 属性指定的是 file:/dev/random 或 file:/dev/urandom ,那么JVM会使用本地种子产生器NativeSeedGenerator,它会调用super()方法,即调用SeedGenerator.URLSeedGenerator(/dev/random)方法进行初始化。

2)如果 java.security.egd 属性或 securerandom.source 属性指定的是其它已存在的URL,那么会调用SeedGenerator.URLSeedGenerator(url)方法进行初始化。

解决方案:

修改 jdk 中 /jre/lib/java.security文件

 

怎么找到linux中jdk安装路径呢?

答案:whereis java命令

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值