我正在尝试在Google计算实例上运行Google AppEngine的本地开发服务器(
java). (我们将计算引擎实例用作测试服务器).
当尝试使用appcfg.sh启动开发服务器时,我们注意到90%的时间,服务器无法启动并在最终启动前挂起10分钟.
我知道服务器还没有启动,因为挂起时该行永远不会打印到控制台:
Server default is running at http://localhost:8080/
有没有人见过这样的东西?
解决方法
简而言之:
– App Engine java SDK使用jetty作为开发应用程序服务器的servlet容器
-Jetty依赖于java.security.SecureRandom
-SecureRandom默认使用来自/ dev / random的熵
– / dev / random将在没有足够的熵可用于读取时阻止
轻微使用GCE实例(例如,仅作为测试appengine服务器),不会快速生成熵.因此,java appengine服务器的重复启动会比/ dev / random更快地消耗熵,从而导致启动时阻塞行为被视为启动时挂起.
您可以通过增加dev appserver的日志记录级别来确认挂起是由SecureRandom问题引起的.您应该看到类似于“init SecureRandom”的消息,然后是阻塞行为.
一些可能的解决方法:
1)将以下内容添加到dev_appserver.sh调用将导致SecureRandom使用/ dev / urandom熵源而不是/ dev / random:
–jvm_flag = “ – Djava.security.egd =文件是:/ dev /./ urandom的”
2)具有更多利用的GCE实例应该更快地收集熵数据,这反过来使得/ dev / random更不容易在随后的开发应用服务器重启时阻塞.