Sergey Chikin
01/16/2018, 11:53 AMoverride val route: Routing.() -> Unit
        get() = {
            get("healthz") {
                val dbState = asyncGetDatabaseState()
                var res = HealthModel(
                        status = Server.status,
                        database = dbState.await(),
                        redis = RedisHealth("null", 0)
                )
                call.respond(res)
            }
        }
    suspend fun getDatabaseState(): DatabaseHealth {
        delay(500) //sleep for 500ms
        return DatabaseHealth(
                host = Config.config[DatabaseConfig.host],
                database = Config.config[DatabaseConfig.database],
                latencyMs = 500
        )
    }
    fun asyncGetDatabaseState() = async {
        getDatabaseState()
    }Caused by: io.ktor.server.engine.BaseApplicationResponse$ResponseAlreadySentException: Response has already been sentorangy
HealthModelSergey Chikin
01/16/2018, 12:07 PMHealthModelSergey Chikin
01/16/2018, 12:36 PMBaseApplicationResponseCaused by: io.ktor.server.engine.BaseApplicationResponse$ResponseAlreadySentException: Response has already been sent
	at io.ktor.server.engine.BaseApplicationResponse$$special$$inlined$apply$lambda$1.doResume(BaseApplicationResponse.kt:30)Sergey Chikin
01/16/2018, 2:51 PMnettyjettynettyorangy
Sergey Chikin
01/16/2018, 2:52 PMorangy
Sergey Chikin
01/16/2018, 3:07 PM0.9.1-alpha-8Sergey Chikin
01/16/2018, 3:11 PMnettyorangy
Sergey Chikin
01/16/2018, 3:32 PMsuspend fun testSuspend(): Int {
    delay(500)
    val random = java.util.Random()
    return random.nextInt(100)
}
fun main(args : Array<String>) {
    embeddedServer(Netty, 9000) {
        install(Routing) {
            get("/healthz") {
                val start = System.currentTimeMillis()
                val calcResult = async { testSuspend() }.await()
                val end = System.currentTimeMillis()
                call.respond("Runtime ${end - start}ms Result ${calcResult}")
            }
        }
    }.start(wait = true)
}orangy
Sergey Chikin
01/16/2018, 4:21 PMcall.respondTextorangy
noncom
01/16/2018, 7:16 PMorangy
orangy
orangy
Sergey Chikin
01/16/2018, 9:46 PMcall.respondcall.respondTextcall.respond(Any)orangy
Sergey Chikin
01/16/2018, 10:01 PMorangy
orangy
Sergey Chikin
01/16/2018, 10:10 PMSergey Chikin
01/16/2018, 10:10 PMSergey Chikin
01/16/2018, 10:24 PMCannot find local variable: name = thisorangy
orangy
Sergey Chikin
01/16/2018, 10:48 PMorangy
Sergey Chikin
01/16/2018, 11:09 PMSergey Chikin
01/16/2018, 11:09 PMorangy
orangy
<http://localhost:9000/healthz>