Rinha de Backend 2024 Q1 - Submissão do @Cadu
Foquei em desempenho nesse projeto, com o lema "menos é mais". Isso significa que houveram tradeoffs e alguns corners cortados, buscando boa performance e latência.
Ou seja, nem tudo aqui vai estar tão bonito e arquitetado o quanto poderia ou deveria estar num projeto real.
graph TD
A[(.)] -->|requisições| B[rinha-ingress:9999]
B -->|requisições| C[rinha-api1]
B -->|requisições| D[rinha-api2]
C -->|consultas| E[(rinha-db)]
D -->|consultas| E
rinha-ingress
HAProxy
no modo TCP
rinha-api-{1,2}
rust 1.76
- Api é com o
ntex
(fork doactix-web
pelo próprio autor do actix) - Runtime é o
tokio
zão das massa. - Banco de dados:
bb8
(pool de conexões)bb8-postgres
(adaptador do bb8 pro postgres)tokio_postgres
(driver do postgres
- Extras:
chrono
pra trampar com datas sem ficar maluco.env_logger
pra printar uns treco enquanto tava desenvolvendo.
- Build multistage copiando o binário para um container
scratch
- literalmente, o container só tem o executável.
rinha-db
postgres:16
fsync
ligado, nada de unlogged tables, ...- Todas as tabelas tem apenas uma letra no nome, e todos os campos também.
- Quanto menos bytes no fio, melhor ;-) Vamos aumentar o SNR kkkkk
- Tweaks de performance para commit assíncrono e emagrecimento do WAL, visto que temos um cenário sem replicações.
- Algumas considerações:
- nada de
alpine
foi usado, de propósito, pois existem algumas considerações de performance importantes com amusl-libc
que atrapalhariam o foco aqui, comparado com aglibc
.
- nada de
Coisas que me ajudaram pelo caminho.
- Imagens docker pequenas:
- Pra avaliar e debuggar algumas coisas do container que eu buildei, usei o
dive
: - Eu quis fazer o binário ser 100% estático, isso significa que eu precisei linkar o glibc dentro também:
- Pra linkar a glibc estaticamente, além da flag, você precisa especifica o arch triplet
- Isso significa que esse projeto, no formato atual, só roda em sistemas linux x86_64
- Pra linkar a glibc estaticamente, além da flag, você precisa especifica o arch triplet
- Pra avaliar e debuggar algumas coisas do container que eu buildei, usei o
- Descobri que não não existe
impl TryFrom<T>
de float pra int em Rust, e que tem uma porradaria de discussões rolando em cima disso.- Ai eu precisei fazer uma validação de float meio capenga, mas mesmo assim tem os links aqui das discussões que são super interessantes, explicando os porquês.
EOF