Há cerca de uma década, bcache emergiu como um sistema de cache de bloco para Linux, proporcionando armazenamento em camadas, onde discos rígidos podiam ser combinados com SSDs para cache. Naquela época, o ZFS no Linux estava longe de ser o que é hoje, e a comunidade Linux ficou animada com a perspectiva de incorporar mais funcionalidades semelhantes ao ZFS. Entretanto, com o avanço das tecnologias, como o NVMe, o interesse por armazenamento em camadas diminuiu, pois os benefícios de custo não compensam o tempo perdido na implementação.
Evolução para um sistema de arquivos completo
Em 2015, foi anunciado que o bcache evoluiria para o bcachefs, um sistema de arquivos completo, gerando grande entusiasmo na comunidade Linux. O bcachefs prometia recursos avançados como compressão integrada, criptografia, somas de verificação e implementações de RAID, o que o colocava como um concorrente direto de sistemas como ZFS e btrfs. No entanto, diferentemente do ZFS, o bcachefs não possuía um módulo DKMS, o que exigia a compilação manual do kernel do bcachefs para testá-lo, tornando seu uso menos acessível.
Desafios na manutenção do bcachefs-tools no Debian
Primeiros passos para empacotamento no Debian
Em 2019, com a expectativa de que o bcachefs fosse integrado ao kernel Linux, surgiu a ideia de empacotar as ferramentas de usuários do bcachefs (bcachefs-tools) no Debian. Embora o kernel Debian não suportasse bcachefs naquela época, a inclusão dessas ferramentas parecia promissora para versões futuras ou para usuários que compilassem seus próprios kernels. O primeiro snapshot git das bcachefs-tools foi incluído no Debian em 29 de agosto de 2019, facilitando a utilização dessas ferramentas.
Complicações com dependências Rust
Em 2023, a versão 1.2 das bcachefs-tools introduziu utilitários escritos em Rust, o que trouxe novos desafios, pois as dependências Rust não eram compatíveis com os requisitos de compilação do Debian. Embora a equipe de Rust no Debian tenha ajudado a flexibilizar as dependências, permitindo que a versão fosse compilada, isso causou desconforto em relação à estabilidade e confiabilidade do software resultante.
A decisão de remover bcachefs-tools do Debian
Impossibilidade de manter bcachefs-tools em versões estáveis
Com o tempo, ficou evidente que manter o bcachefs-tools no Debian, especialmente em versões estáveis, seria impraticável. A exigência de dependências específicas e o rápido envelhecimento das versões tornavam impossível fornecer suporte a longo prazo para essas ferramentas. Após várias tentativas de atualizações e uma crescente insatisfação da comunidade, decidiu-se que o bcachefs-tools seria removido do Debian, embora, após discussão, tenha sido decidido apenas orfanar o pacote, deixando-o disponível para quem quisesse continuar o trabalho.
Lições aprendidas e considerações para o futuro
A experiência com o bcachefs-tools serve de alerta para aqueles que consideram utilizar bcachefs em produção. Antes de adotar esse sistema de arquivos, é crucial avaliar a viabilidade de suporte a longo prazo, considerando que a falta de estabilidade nas dependências pode tornar o software inutilizável em ambientes de produção.
Reflexões finais sobre a jornada do bcachefs-tools
A jornada do bcachefs-tools no Debian termina com uma lição importante: a estabilidade e o suporte a longo prazo são fatores cruciais para a adoção de qualquer tecnologia, especialmente em ambientes de produção. O futuro do bcachefs dependerá da capacidade de sua comunidade em oferecer um suporte sustentável e confiável.