Notas de PHP e Web

Artigos curtos e práticos sobre PHP, Laravel, bancos de dados e engenharia web (site estático).

Banco de Dados 11 de fevereiro de 2024 ~3 min

Transações: quando usar e como evitar deadlocks

Transações: quando usar e como evitar deadlocks — Banco é onde os custos aparecem. Índices e transações bem usadas eliminam 80% das dores.

O objetivo aqui é prático: decisões pequenas que melhoram confiabilidade e manutenção. Se você já lidou com bugs intermitentes, sabe o valor de padrões simples.

Como eu abordo

  • Comece com o caso real (o que está quebrando ou ficando caro).
  • Defina uma regra pequena e aplicável (sem reescrever tudo).
  • Instrumente: teste, log ou métrica para confirmar melhora.
  • Documente o “porquê” em poucas linhas para não perder contexto.

Armadilhas comuns

  • Otimizar cedo sem medir.
  • Misturar camadas (controller fazendo SQL, por exemplo).
  • Não registrar contexto (request id, rota, usuário) nos logs.
  • Apostar em “mágica” de framework sem entender o fluxo.
Dica: prefira mudanças pequenas e reversíveis. Se não dá para reverter, você está fazendo uma aposta grande demais.

Checklist rápido

  • Qual é o risco principal (segurança, performance, disponibilidade)?
  • Como eu valido a mudança (teste, log, métrica)?
  • O que pode dar errado e como reverter?
  • Quem mantém isso daqui a 3 meses?

Trecho de código

nginx
# Nginx + PHP-FPM: timeouts e buffers (exemplo)
fastcgi_connect_timeout 5s;
fastcgi_send_timeout 30s;
fastcgi_read_timeout 30s;
fastcgi_buffering on;

Se esta nota te poupou tempo, anote o que você ajustou e por quê. Isso vira um guia interno com o tempo.

#sql #locks #postgres #transactions #http #xdebug #http2
Autor
Rafael Almeida
Contato
rafael.almeida.dev@example.com