Ktor 需要 1 小时(永远)启动

Ktor needs 1 hour(forever) to boot up

我有一个 ktor 应用程序。我在开发模式下 运行 时工作正常。我通过复制 gradle 应用程序插件提供的内容将其打包在 docker 图像中。这在我的本地机器 8 核上也能正常工作。但现在奇怪的是。当我在租来的 V-Server 上做完全相同的事情时,也像我的本地系统一样 运行ning Ubuntu-20.04,ktor 非常慢。

docker-compose logs server:
server           | 2021-08-24 08:00:23.337 [main] INFO  ktor.application - Autoreload is disabled because the development mode is off.
server           | 2021-08-24 08:25:35.048 [main] INFO  ktor.application - Autoreload is disabled because the development mode is off.
server           | 2021-08-24 09:18:48.246 [main] INFO  c.e.e.s.TemplateStore - Starting to parse Sentences
server           | 2021-08-24 09:18:48.345 [main] INFO  c.e.e.s.TemplateStore - Finished parsing sentences
server           | 2021-08-24 09:18:48.346 [main] INFO  ktor.application - Responding at http://0.0.0.0:8080
server           | 2021-08-24 09:18:48.347 [main] INFO  ktor.application - Application started in 3193.32 seconds.
 Application started in 3193.32 seconds

可以在此处找到源代码 https://github.com/1-alex98/whatisthat。它有一个 docker-compose.yml 定义正在启动的整个 docker 容器。 本地系统 32 GB 内存 + 8 核。 V-Server 4 gb Ram + 2 核(htop 显示大量资源是免费的)。

我正在寻找有关世界上可能导致此行为的原因的想法。或者调试方法。

更新: 似乎永远读取一个文件:

"main" #1 prio=5 os_prio=0 cpu=652.14ms elapsed=173.92s tid=0x00007f01d4016000 nid=0xe runnable  [0x00007f01dace6000]
   java.lang.Thread.State: RUNNABLE
    at java.io.FileInputStream.readBytes(java.base@11.0.12/Native Method)
    at java.io.FileInputStream.read(java.base@11.0.12/FileInputStream.java:279)
    at java.io.FilterInputStream.read(java.base@11.0.12/FilterInputStream.java:133)
    at sun.security.provider.NativePRNG$RandomIO.readFully(java.base@11.0.12/NativePRNG.java:424)
    at sun.security.provider.NativePRNG$RandomIO.ensureBufferValid(java.base@11.0.12/NativePRNG.java:526)
    at sun.security.provider.NativePRNG$RandomIO.implNextBytes(java.base@11.0.12/NativePRNG.java:545)
    - locked <0x00000000c7571158> (a java.lang.Object)
    at sun.security.provider.NativePRNG$Blocking.engineNextBytes(java.base@11.0.12/NativePRNG.java:268)
    at java.security.SecureRandom.nextBytes(java.base@11.0.12/SecureRandom.java:751)
    at kotlin.random.AbstractPlatformRandom.nextBytes(PlatformRandom.kt:47)
    at kotlin.random.Random.nextBytes(Random.kt:260)
    at com.example.routes.websocket.WebsocketRoutingKt.<clinit>(WebsocketRouting.kt:40)
    at com.example.plugins.RoutingKt$routing.invoke(Routing.kt:13)
    at com.example.plugins.RoutingKt$routing.invoke(Routing.kt:11)
    at io.ktor.routing.Routing$Feature.install(Routing.kt:106)
    at io.ktor.routing.Routing$Feature.install(Routing.kt:88)
    at io.ktor.application.ApplicationFeatureKt.install(ApplicationFeature.kt:68)
    at io.ktor.routing.RoutingKt.routing(Routing.kt:129)
    at com.example.plugins.RoutingKt.routing(Routing.kt:11)
    at com.example.ApplicationKt$main.invoke(Application.kt:18)
    at com.example.ApplicationKt$main.invoke(Application.kt:14)
    at io.ktor.server.engine.internal.CallableUtilsKt.executeModuleFunction(CallableUtils.kt:50)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading$launchModuleByName.invoke(ApplicationEngineEnvironmentReloading.kt:317)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading$launchModuleByName.invoke(ApplicationEngineEnvironmentReloading.kt:316)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading.avoidingDoubleStartupFor(ApplicationEngineEnvironmentReloading.kt:341)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading.launchModuleByName(ApplicationEngineEnvironmentReloading.kt:316)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading.access$launchModuleByName(ApplicationEngineEnvironmentReloading.kt:30)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading$instantiateAndConfigureApplication.invoke(ApplicationEngineEnvironmentReloading.kt:304)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading$instantiateAndConfigureApplication.invoke(ApplicationEngineEnvironmentReloading.kt:295)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading.avoidingDoubleStartup(ApplicationEngineEnvironmentReloading.kt:323)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading.instantiateAndConfigureApplication(ApplicationEngineEnvironmentReloading.kt:295)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading.createApplication(ApplicationEngineEnvironmentReloading.kt:136)
    at io.ktor.server.engine.ApplicationEngineEnvironmentReloading.start(ApplicationEngineEnvironmentReloading.kt:268)
    at io.ktor.server.netty.NettyApplicationEngine.start(NettyApplicationEngine.kt:174)
    at com.example.ApplicationKt.main(Application.kt:21)
    at com.example.ApplicationKt.main(Application.kt)

这是一台新租用的服务器,但我猜它有问题

docker-compose 很慢,我的程序没有启动似乎是由于对 /dev/urandom 的输入不足(不够好)。安装 https://github.com/smuellerDD/jitterentropy-rngd 解决了问题。