运行Google Compute Engine实例的GAE开发服务器<phew>

alo*_*loo 6 java google-app-engine google-compute-engine

我正在尝试在Google计算实例上运行Google AppEngine的本地开发服务器(java).(我们将计算引擎实例用作测试服务器).

当尝试使用appcfg.sh启动开发服务器时,我们注意到90%的时间,服务器无法启动并在最终启动前挂起10分钟.

我知道服务器还没有启动,因为挂起时该行永远不会打印到控制台:

Server default is running at http://localhost:8080/
Run Code Online (Sandbox Code Playgroud)

有没有人见过这样的东西?

sho*_*man 10

简而言之:

- 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更不容易在随后的开发应用服务器重启时阻塞.