mirror of
https://github.com/actix/actix-website
synced 2025-06-27 15:39:02 +02:00
Architecture diagrams of HttpServer and Connection lifecycle (#148)
* add arch diagrams and menu * fix colors for arch diagrams * refine architecture diagrams, ready for review * capitalize titles and add mmdc instruction * apply code review requested changes * Add links to accept, worker and dispatcher too
This commit is contained in:
committed by
Yuki Okushi
parent
53214f4727
commit
c1a8103cbc
28
static/img/diagrams/connection_accept.mmd
Normal file
28
static/img/diagrams/connection_accept.mmd
Normal file
@ -0,0 +1,28 @@
|
||||
sequenceDiagram
|
||||
|
||||
participant ServerBuilder
|
||||
participant mio
|
||||
participant Accept
|
||||
participant WorkerClient
|
||||
|
||||
|
||||
ServerBuilder->>Accept: start(socks, workers)
|
||||
loop Continuous: poll
|
||||
Accept->>mio: mio::Poll::poll()
|
||||
alt poll() -> TIMER | CMD
|
||||
Accept-->>Accept: process_*
|
||||
else poll() -> NOTIFY
|
||||
Accept->>Accept: backpressure
|
||||
else poll() -> OTHER(token)
|
||||
Accept-->>Accept: accept_one(Conn)
|
||||
loop while exist WorkerClient
|
||||
Accept->>WorkerClient: send(Conn)
|
||||
alt send(Conn) -> Ok(_)
|
||||
Note over Accept: break loop
|
||||
else send(Conn) -> Err(_)
|
||||
Accept->>ServerBuilder: worker_faulted(idx)
|
||||
Accept->>Accept: remove worker, get next worker
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
4
static/img/diagrams/connection_accept.svg
Normal file
4
static/img/diagrams/connection_accept.svg
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 15 KiB |
34
static/img/diagrams/connection_overview.mmd
Normal file
34
static/img/diagrams/connection_overview.mmd
Normal file
@ -0,0 +1,34 @@
|
||||
sequenceDiagram
|
||||
|
||||
participant ServerBuilder
|
||||
participant Accept
|
||||
participant WorkerClient
|
||||
participant Worker
|
||||
participant Dispatcher
|
||||
|
||||
ServerBuilder->>Accept: start(socks, workers)
|
||||
|
||||
Note over Accept: accept Connections
|
||||
loop poll connections on sockets
|
||||
activate Accept
|
||||
Accept-->>Accept: poll() --> Conn
|
||||
Note over Accept: backpressure logic
|
||||
Accept->>WorkerClient: send(Conn)
|
||||
end
|
||||
deactivate Accept
|
||||
|
||||
Note over Worker: process Connections
|
||||
loop Worker as Future::poll
|
||||
activate Worker
|
||||
Worker->>WorkerClient: rx.poll_next()
|
||||
Note over Worker: Service factories
|
||||
Worker-->>Dispatcher: new(stream)
|
||||
end
|
||||
deactivate Worker
|
||||
|
||||
Note over Dispatcher: process Requests
|
||||
loop Dispatcher::poll
|
||||
activate Dispatcher
|
||||
Dispatcher-->>Dispatcher: Dispatch requests
|
||||
end
|
||||
deactivate Dispatcher
|
4
static/img/diagrams/connection_overview.svg
Normal file
4
static/img/diagrams/connection_overview.svg
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 15 KiB |
29
static/img/diagrams/connection_request.mmd
Normal file
29
static/img/diagrams/connection_request.mmd
Normal file
@ -0,0 +1,29 @@
|
||||
sequenceDiagram
|
||||
|
||||
participant HttpServer
|
||||
participant HttpServiceHandler
|
||||
participant HSHR
|
||||
participant State
|
||||
participant Dispatcher
|
||||
participant Tokio
|
||||
|
||||
Note over HSHR, State: HttpServiceHandlerResponse
|
||||
|
||||
HttpServer-->>HttpServiceHandler: eventually build...
|
||||
alt Protocol::HTTP1
|
||||
HttpServiceHandler->>Dispatcher: H1::Dispatcher::new()
|
||||
HttpServiceHandler->>State: State::H1(Dispatcher)
|
||||
else Protocol::HTTP2
|
||||
HttpServiceHandler->>State: State::H2Handshake
|
||||
end
|
||||
HttpServiceHandler->>HSHR: HttpServiceHandlerResponse::new(State)
|
||||
HttpServiceHandler-->>Tokio: StreamService->Tokio::spawn(HttpServiceHandlerResponse as Future)
|
||||
|
||||
Tokio->>HSHR: poll()
|
||||
alt State::H2Handshake
|
||||
HSHR->>Dispatcher: H2::Dispatcher::new(stream,services)
|
||||
HSHR->>HSHR: poll()
|
||||
else
|
||||
HSHR->>Dispatcher: poll()
|
||||
end
|
||||
Note over Dispatcher: requests loop
|
4
static/img/diagrams/connection_request.svg
Normal file
4
static/img/diagrams/connection_request.svg
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 15 KiB |
34
static/img/diagrams/connection_worker.mmd
Normal file
34
static/img/diagrams/connection_worker.mmd
Normal file
@ -0,0 +1,34 @@
|
||||
sequenceDiagram
|
||||
|
||||
participant ServerBuilder
|
||||
participant WorkerClient
|
||||
participant Worker
|
||||
participant StreamService
|
||||
participant HttpServiceHandler
|
||||
participant Tokio
|
||||
|
||||
ServerBuilder-->>Tokio: spawn(Worker)
|
||||
|
||||
Tokio-->>Worker: poll()
|
||||
alt WorkerState::Available
|
||||
loop
|
||||
Worker->>WorkerClient: rx.poll_next()
|
||||
WorkerClient->>Worker: WorkerCommand(Conn)
|
||||
Worker->>Worker: check_readiness()
|
||||
alt check_readiness() -> Ok(true)
|
||||
Note over Worker,StreamService: Worker::services[Conn.token]
|
||||
Worker-->>StreamService: call(ServerMessage::Connect(stream))
|
||||
StreamService->>HttpServiceHandler: call(stream)
|
||||
HttpServiceHandler->>StreamService: HttpServiceHandlerResponse as Future
|
||||
StreamService->>Tokio: spawn(HttpServiceHandlerResponse)
|
||||
|
||||
else check_readiness() -> Ok(false)
|
||||
Worker-->>Worker: WorkerState::Unavailable
|
||||
else check_readiness() -> Err(token,idx)
|
||||
Worker-->>Worker: WorkerState::Restarting
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
Note over HttpServiceHandler: process connection
|
4
static/img/diagrams/connection_worker.svg
Normal file
4
static/img/diagrams/connection_worker.svg
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 16 KiB |
32
static/img/diagrams/http_server.mmd
Normal file
32
static/img/diagrams/http_server.mmd
Normal file
@ -0,0 +1,32 @@
|
||||
sequenceDiagram
|
||||
|
||||
participant HttpServer
|
||||
participant ServerBuilder
|
||||
participant Worker
|
||||
participant StreamNewService
|
||||
participant HttpService
|
||||
participant HttpServiceResponse
|
||||
participant Tokio
|
||||
|
||||
|
||||
HttpServer-->>HttpService: build...
|
||||
HttpServer->>ServerBuilder: listen(addr,Fn->HttpService)
|
||||
ServerBuilder->>StreamNewService: create(addr,Fn->HttpService)
|
||||
HttpServer->>ServerBuilder: start()
|
||||
ServerBuilder->>Worker: start(StreamNewService)
|
||||
|
||||
Worker->>StreamNewService: InternalServiceFactory::create()
|
||||
StreamNewService->>HttpService: new_service()
|
||||
HttpService->>HttpServiceResponse: HttpServiceResponse::new()
|
||||
HttpService->>StreamNewService: HttpServiceResponse as Future
|
||||
StreamNewService->>Worker: StreamService(HttpServiceResponse) as Future
|
||||
Worker-->>Tokio: spawn(StreamService(HttpServiceResponse)).map(Worker))
|
||||
Tokio-->>HttpServiceResponse: poll()
|
||||
HttpServiceResponse-->>Tokio: Ready(Worker(HttpServiceHandler))
|
||||
|
||||
loop Worker process messages
|
||||
Tokio-->>Worker: poll->Pending...
|
||||
activate Worker
|
||||
Note over Worker: pull messages
|
||||
deactivate Worker
|
||||
end
|
4
static/img/diagrams/http_server.svg
Normal file
4
static/img/diagrams/http_server.svg
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 16 KiB |
Reference in New Issue
Block a user