Gerenciamento de Swap - Evitando Esgotamento de Memoria no Linux

Gerenciamento de Swap - Evitando Esgotamento de Memoria no Linux

O que e Swap?

Swap e uma area de memoria virtual em disco que o Linux usa quando a RAM fisica esta cheia. Ele funciona como uma rede de seguranca -- quando a RAM acaba, os processos podem continuar executando em vez de serem imediatamente encerrados. No entanto, como o swap envolve I/O de disco, ele e ordens de magnitude mais lento que a RAM.

Existem duas formas de swap:

Forma Descricao
Particao swap Particao de disco dedicada. Ligeiramente mais rapida, mas dificil de redimensionar
Swapfile Arquivo regular no sistema de arquivos. Facil de redimensionar, agora a abordagem padrao

Swap nao resolve escassez de memoria -- apenas a adia. Swapping sustentado (thrashing) e um problema de desempenho e um sinal de um problema subjacente de memoria. Adicionar mais swap ganha tempo, mas nao e uma correcao.

Como Verificar o Uso de Swap

free -h e a maneira mais rapida de verificar o swap. Observe a linha Swap: -- se used cresce ao longo do tempo, o sistema esta fazendo swap.

free -h
               total        used        free      shared  buff/cache   available
Mem:           3.8Gi       2.1Gi       408Mi        45Mi       1.3Gi       1.4Gi
Swap:          2.0Gi       512Mi       1.5Gi

Para listar dispositivos swap com detalhes, use swapon --show:

swapon --show
NAME      TYPE SIZE USED PRIO
/swapfile file   2G 512M   -2

Para observar a atividade de swap ao longo do tempo, use vmstat. Observe as colunas si (swap in) e so (swap out):

vmstat 1 5
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 0  0 524288 418032  98304 1350656    0    0     2     5   45   80  2  1 97  0  0
 0  1 524288 200000  98304 1350672    8   12     0    20   65  120  2  1 90  7  0

Valores si/so nao-zero sustentados indicam thrashing.

Como Criar um Swapfile

O procedimento padrao em sistemas Ubuntu / Debian para adicionar capacidade de swap:

sudo fallocate -l 2G /swapfile
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile

Se fallocate nao estiver disponivel (NFS ou alguns sistemas de arquivos), use dd em vez disso: dd if=/dev/zero of=/swapfile bs=1M count=2048

Verifique com swapon --show:

swapon --show
NAME      TYPE SIZE USED PRIO
/swapfile file   2G   0B   -2

Tornar o Swap Persistente Entre Reinicializacoes

Adicione uma entrada em /etc/fstab:

echo '/swapfile none swap sw 0 0' | sudo tee -a /etc/fstab

Apos editar /etc/fstab, valide com sudo swapon -a antes de reiniciar. Um erro de sintaxe no fstab pode impedir o sistema de inicializar.

Remover um Swapfile

sudo swapoff /swapfile
sudo rm /swapfile

Tambem remova a linha correspondente do /etc/fstab.

Como Ajustar o Swappiness

swappiness e um parametro do kernel (0-100) que controla quao agressivamente o kernel usa swap. O padrao e 60.

Valor Comportamento
0 Swap apenas quando a RAM esta quase esgotada (nao desabilita swap completamente)
10-30 Cargas de trabalho desktop/estacao -- preferir RAM
60 Padrao
100 Swap agressivamente

Verificar o valor atual:

cat /proc/sys/vm/swappiness

Alterar temporariamente (reseta ao reiniciar):

sudo sysctl vm.swappiness=10

Persistir a configuracao:

echo 'vm.swappiness=10' | sudo tee /etc/sysctl.d/99-swappiness.conf
sudo sysctl -p /etc/sysctl.d/99-swappiness.conf

Para servidores de banco de dados (MySQL, PostgreSQL), reduzir swappiness para 1-10 e um passo comum de ajuste em producao. Swap sob cargas de banco de dados causa picos de latencia de consultas que sao dificeis de diagnosticar sem esse contexto.

O que Acontece Quando a Memoria se Esgota?

Quando tanto RAM quanto swap estao cheios, o OOM killer (Out-Of-Memory killer) do kernel encerra um processo para liberar memoria. Isso causa falhas inesperadas na aplicacao. Verifique OOM kills no log do kernel:

dmesg | grep -i 'oom\|killed process\|out of memory'
[123456.789] Out of memory: Killed process 1234 (mysqld) total-vm:2097152kB, anon-rss:1048576kB

Ou via journal do systemd:

journalctl -k | grep -i 'oom\|killed'

Proteger um Processo Especifico de OOM Kill (Temporario)

Ajuste o score OOM para um processo critico. Os valores variam de -1000 (nunca encerrar) a 1000 (encerrar primeiro):

echo -1000 | sudo tee /proc/$(pgrep mysqld)/oom_score_adj

Essa configuracao nao persiste entre reinicializacoes. Use-a apenas como solucao temporaria enquanto aborda o problema subjacente de memoria.

Proximas Leituras