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