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更不容易在随后的开发应用服务器重启时阻塞.
| 归档时间: |
|
| 查看次数: |
531 次 |
| 最近记录: |