tomcat启动一直卡在Root WebApplicationContext: initialization completed

  |   0 评论   |   0 浏览

主要是因为阿里云的熵池太小 熵池的大小是根据键盘 鼠标之类的噪音产生的数 然后/dev/random会根据熵池来生成随机数 而生成需要有足够的熵池里的噪音数 如果没有达到的话就会一直阻塞 tomcat启动的时候为了生成session id就会获取这个随机数来生成密匙 所以才出现上面的情况 一直阻塞在等待熵池里的数满足生成随机数的大小 3分钟以后熵池里的数够大了才开始部署 所以我们可以使用rngd来增大熵池 因为docker容器的熵池都是共享的宿主机的 所以只要增大宿主机的熵池就可以了 在容器内是没办法通过rngd修改熵池的因为没有权限修改宿主机的东西 只能通过上面链接里提到的修改jre或者tomcat的方法
————————————————
yum install -y rng-tools
systemctl start rngd
cp /usr/lib/systemd/system/rngd.service /etc/systemd/system
vi /etc/systemd/system/rngd.service

找到ExecStart 在最后加上-r /dev/urandom

ExecStart=/sbin/rngd -f -r /dev/urandom

重新载入服务
systemctl daemon-reload

重启服务
systemctl restart rngd
————————————————


标题:tomcat启动一直卡在Root WebApplicationContext: initialization completed
作者:gao1feng
地址:http://gao1feng.top/articles/2017/05/20/1571305612651.html