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