Skip to content

Latest commit

 

History

History
68 lines (47 loc) · 2.46 KB

README.md

File metadata and controls

68 lines (47 loc) · 2.46 KB

Axum request timeout

I'm trying to set a request timeout for an Axum server.

This is a test repo to reproduce the problem with a minimal amount of code.

The original issue: torrust/torrust-index#204

I think there are two different timeouts:

Timeout for the handlers

I think this is the discussion opened in the Axum repo:

tokio-rs/axum#1383

With the solution provided in the discussion, I can set a timeout for the handlers. If the handler takes more than 5 seconds, the server will return a 500 error.

It's the current implementation in this repo. You can test it with:

$ telnet localhost 3001
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
GET / HTTP/1.0

HTTP/1.0 500 Internal Server Error
content-type: text/plain; charset=utf-8
content-length: 37
date: Mon, 19 Jun 2023 16:00:56 GMT

`GET /` failed with request timed outConnection closed by foreign host.

After 5 seconds, the server returns a 500 error. You have to press "return" twice to send the GET / HTTP/1.0 request.

Timeout for the client

ActixWeb provides a client request timeout. If you run a similar example but with ActixWeb you will see:

$ telnet localhost 3001
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
HTTP/1.1 408 Request Timeout
content-length: 0
connection: close
date: Mon, 19 Jun 2023 15:02:54 GMT

Connection closed by foreign host.

It will send a 408 Request Timeout response if you do not send any request after 5 seconds. It's the default timeout for the ActixWeb server.

I'm trying to do the same for Axum. The following could be a solution: torrust/torrust-tracker#324 (comment).

Links