O sistema de arquivos XFS é considerado por muitos de alto desempenho, é um sistema de arquivos de 64 bits sendo compatível com sistemas de 32
bits. Foi desenvolvido inicialmente para o SO IRIX, depois portado para o kernel GNU/Linux.
O kernel e a maioria dos sistemas GNU/Linux dão suporte durante a instalação para usar o XFS como sistema de arquivos de suas partições, e assim, como os outros
sistemas de arquivos apresentados até agora, possui journaling.
Principais vantagens
Possui journaling em sua estrutura, porém o journal no XFS se comporta de forma similar a outros sistemas de arquivos, mantendo somente a gravação dos
metadados dos arquivos no journaling, fazendo com que a consistência do sistema de arquivos como um todo fique preservada.
XFS faz uso do journaling Lógico, assim, se um arquivo estiver sendo usado e as alterações dos metadados não forem gravadas antes de um erro ou falha (falta de
energia por exemplo), todo ou uma parte do arquivo poderá ficar corrompido, já que seu conteúdo não foi salvo.
É um sistema de arquivos de 64 bits compatível com sistemas de 32 bits também.
Em sistemas 64 bits há um limite de tamanho de 8 EiB para cada arquivo, já em sistema de 32 bits o tamanho máximo do volume ou arquivo é limitado a 16 TiB.
Tamanhos de blocos variáveis: Tamanho de blocos do sistema representa a unidade de alocação mínima. XFS permite que o sistema de arquivos seja criado
com tamanhos de blocos que variam entre 512 bytes e 64 kilobytes, permitindo que o sistema de arquivos ajuste-o para o uso esperado.
Quando está trabalhando com muitos arquivos pequenos, um tamanho de bloco pequeno é o ideal, mas para um sistema lidando principalmente com arquivos
grandes, um tamanho de bloco maior pode proporcionar uma vantagem quanto ao desempenho.
A desfragmentação online: Embora o XFS use alocação com atraso, isso melhora significativamente a resistência do sistema de arquivos para os problemas de
fragmentação. XFS fornece um utilitário de desfragmentação que pode desfragmentar os arquivos com o sistema de arquivos em uso.
A criação do sistema de arquivos XFS é muito rápida.
Redimensionamento online: XFS oferece a 'xfs_growfs', utilitário para executar o redimensionamento online de sistemas de arquivos XFS.
Espaço onde se encontra o sistemas de arquivos XFS podem ser alterados desde que haja espaço restante não alocado no dispositivo para adicionar ao XFS. Este
recurso é normalmente usado em conjunto com o gerenciamento de volume, caso contrário a partição que mantém o sistema de arquivos terá que ser ampliada
separadamente.
Utilitários para gerenciamento do sistema de arquivos inclusos no xfsprogs, tais para checagem do mesmo, aplicação do sistema de arquivos,
ajustes no sistema de arquivos entre outros.
Cotas de disco: Cotas para sistemas de arquivos XFS são ativadas quando o sistema de arquivos é montado, diferente de outros sistemas de arquivos que na
maioria exigem serem montados primeiro para depois ativar a quota com o quotaon.
Trabalha muito bem com arquivos grandes (leitura e gravação), principalmente em sistemas que armazenam muitos arquivos de grande tamanho. Lembre-se o
XFS foi desenvolvido para trabalhar em grandes sistemas, principalmente de 64 bits.
Principais desvantagens
Redimensionamento do XFS não pode ser usado para diminuir o tamanho do mesmo, apenas aumentar.
Operações usando metadados em XFS são muito lentas do que com outros sistemas de arquivos, produzindo mau desempenho em operações como deleções em
massa de grandes números de arquivos pequenos.
[1] Comentário enviado por removido em 22/06/2012 - 19:41h
Olha rapaz, achei o seu artigo excelente e fico satisfeito em ser o primeiro a comentá-lo e mais ainda por ter saído do assunto em voga "Pinguim x M$" que tá dando no saco!
Quanto aos filesystems, venho usando o reiserfs para o sistema raiz e o xfs para /home e não tenho do que me queixar, exceto o fato do Debian não incluir o reiserfs como opção no Debian Installer, em relação a isso fiz uma dica a respeito:
Como sugestão, você poderia solicitar a adição do esquema de particionamento para cada um dos sistemas de arquivos junto a moderação do VOL, o que facilitaria a vida daqueles que vierem a criar novas partições.
[5] Comentário enviado por danielsath em 24/06/2012 - 18:06h
Parabens, muito bom. So gostaria de saber a respeito de uma particao que eu encontrei aqui com o nome extend, que estava querendo saber que sistema de arquivos ela utilizar
[10] Comentário enviado por lcnrj em 30/06/2012 - 13:47h
Uso o reiserfs há anos, estou pensando em mudar para xfs no meu hd de 1.5TB mas ouvi falar que na falta de luz ele já era. Quando pensei no ext4 me disseram que ele "gasta" mais espaço no HD. Tenho um misto de muitos arquivos pdf pequenos e muitos arquivos com mais de 250MB. Qual a sua sugestão...obrigado!
[11] Comentário enviado por removido em 30/06/2012 - 14:09h
Ola amigo lcnrj,
Você leu o artigo inteiro ? pois dei claras explicações durante o artigo e no final deixei algumas sugestões de uso.
Para poder dá uma sugestão de uso ideal, preciso saber qual o esquema de particionamento está sendo usado ou que pretende usar ?
Mas antes mesmo de informar, digo que a melhor solução para seu caso seria usar o ext4 no /home, pois os arquivos que citou ficam localizados no /home né isso ? o ext4 é bem rápido tem um ótimo suporte junto ao kernel, além disso trabalha muito bem com arquivos grandes e pequenos(tanto na leitura quanto na gravação).
*** Esclarecimento****
Qualquer sistema de arquivos, pelo menos até este momento pode ser corrompido, com uma queda de energia, o que existe em si é sistemas de arquivos mas consistentes que outros como foi explicado no artigo.
[12] Comentário enviado por Tacioandrade em 11/07/2012 - 00:58h
Muito obrigado pelo artigo, acabei além de conhecer mais sobre os FS's do mercado Linux, com o que você falou sobre o JFS:
"Reparação muito eficaz de um disco com badblocks, ele consegue marcar os setores defeituosos com muita precisão, algo que outros sistemas de arquivos para Linux não fazem."
Vou tentar reavivar uns 20 HDs de la da empresa que estão em uma caixa para descarte por problemas de BadBlock. =)
[13] Comentário enviado por removido em 11/07/2012 - 11:44h
Por nada amigo Tacioandrade,
Mas lembre-se que badblocks influência diretamente no desempenho e não é garantido que o mesmo não ficará com outros badblocks, já que como tem vários setores defeituosos no disco.
[14] Comentário enviado por jarlisson em 20/07/2012 - 14:56h
Ótimo.
Sempre lia esses nomes, mas não sabia o que significavam. Sò sabia que funcionava em um sistema, mas nao no outro, e desse via os arquivos daquele etc. Muito bom saber o porquê.
[16] Comentário enviado por removido em 23/07/2012 - 11:26h
Simples Jarlisson !
Estudando por livros digitais e impressos, estudando pela documentação que os desenvolvedores deixam disponível, pesquisando e estudando pela internet e principalmente, mas principalmente mesmo colocando em prática toda informação estudada e assimilada fazendo uma bateria de testes para poder comprovar o comportamento de todos os sistemas de arquivos abordados no artigo.
[18] Comentário enviado por rafamarini em 19/11/2012 - 01:32h
Olá, excelente artigo!
Eu tenho uma duvida em relação ao JFS!
O Journaling que o Sistema de Arquivos JFS utiliza é o Journaling Lógico, correto?
Então, o Journaling Lógico guarda em seu log os metadados de arquivos que sofreram uma alteração recentemente, porém minha dúvida é o seguinte:
-Quando houver um evento de falha (uma queda de luz), ao religar o equipamento ele irá restaurar os dados utilizando o log realizado pelo journaling, como ele recupera os arquivos somente possuindo os seus metadados e não os dados como o Journal Físico?
[19] Comentário enviado por removido em 19/11/2012 - 11:46h
Obrigado pelos comentários pessoal!
Respondendo as perguntas feitas pelo amigo rafamarini.
[18] Comentário enviado por rafamarini em 19/11/2012 - 01:32h:
O Journaling que o Sistema de Arquivos JFS utiliza é o Journaling Lógico, correto?
Obrigado pela atenção!
R. Correto
[18] Comentário enviado por rafamarini em 19/11/2012 - 01:32h:
-Quando houver um evento de falha (uma queda de luz), ao religar o equipamento ele irá restaurar os dados utilizando o log realizado pelo journaling, como ele recupera os arquivos somente possuindo os seus metadados e não os dados como o Journal Físico?
Obrigado pela atenção!
R. Os metadados também armazena informação sobre a localização dos arquivos no sistema de arquivos, sendo assim, caso computador desligue de forma inesperada no momento da leitura ou escrita de um arquivo, o journal tem no log a informação(metadados) onde esta localizado os blocos do arquivo para tentar restaurar o mesmo, se necessário repetitivamente.
Em um evento citado por você dificilmente perderá o arquivo por completo. por que quando um arquivo é aberto para leitura e ou escrita, o linux cria uma cópia do mesmo, chamado de arquivo swap. assim todas as alterações feitas no arquivo, na verdade são feitas na cópia.
Quando o arquivo é salvo as alterações feitas na cópia são sincronizadas para o arquivo original pelo kernel de forma tardia ou não. Poderá ainda perder se o conteúdo do arquivo estiver em algum bloco defeituoso (bad block) ou se o journal não recebeu a tempo os metadados.
[21] Comentário enviado por vinteumdoonze em 16/03/2013 - 23:15h
Poxa, muito bom o seu artigo, estou estudando para LPI e aprendi muito aqui sobre File System, sei que o conteudo abordado no artigo é basico e devo procurar outras fontes, mas já foi uma grande ajuda para a compreenção do assunto.
Esta de parabéns.
[22] Comentário enviado por galactus em 17/03/2013 - 19:21h
Olá. Gostei do artigo, mas gostaria de deixar meus dois centavos...
Primeiro que o XFS já está muito mais seguro do que antigamente. Em kerneis antigos, realmente, em quedas de energia você poderia corromper dados, mas nas novas versões do XFS e dos kerneis não. Estes benchmarks sintéticos onde você formata um HD e faz os testes logo em seguida não condizem com a realidade de uma sistema em pleno uso, e principalmente com muito tempo de uso! Já li comentários inclusive do principal desenvolvedor do ext4 que estes tipos de testes não mostram a vida real de uma sistema de arquivos, por isso ele não leva muito em consideração esses tipos de testes.
Também assisti a uma palestra postada no Youtube do desenvolvedor do XFS da RedHat falando coisa parecida. São quase 50 minutos dele respondendo a perguntas da galera, quem tiver curiosidade de assisitir é só procurar por: XFS_ Recent and Future Adventures in Filesystem Scalability
Por exemplo, o pessoal olha esses números nus e crus e vai achar que o JFS é uma lesma! Mesmo estando defasado, não é assim. O JFS foi criado numa época em que cada pulso de clock importava, pois eram poucos e muito caros. Portanto seu objetivo era não sobrecarregar o processador e ser seguro. Instale ele numa máquina antiga com apenas um núcleo e comece a fazer mais de uma coisa ao mesmo tempo que você vai ver a que o JFS veio! Olha aqui esse meu video: http://www.youtube.com/watch?v=OCevVWiZCks
O é ext4 pode ser mais rápido enquanto tem poucas requisições sobre ele, mas é só começar a aumentar o número de requisições que a coisa fica feia, na prática você nota como se o sistema ficasse "preso" ao que ele está fazendo e passa a responder muito lentamente! Quando não dá umas congeladas. O XFS tem reserva de requisições por padrão, para não "esgotar" o sistema de arquivos rapidamente quando muitas requisições são feitas ao mesmo tempo. Eu tenho uma servidor multimedia em casa e o XFS dá banho no ext4 nisso. Fora o servidor são mais 4 máquinas, comece a abrir vários vídeos de um mesmo HD pra você ver a diferença. Melhor que ele pra streaming de video em rede só o ZFS com RAID, parece que nem faz força. Desculpem pela redação, acabou ficando quase 50 reais.... hehehehe Mas era só!
[24] Comentário enviado por AprendiNoLinux em 20/12/2014 - 15:03h
Fantástico artigo...
Andei pesquisando hoje sobre armazenamento e não consegui chegar em conclusão alguma rsrs.
Pelas possíveis mudanças de tamanho nas partições, a opção XFS foi descartada.
Parece que vou manter ext4 com lvm...
[25] Comentário enviado por bl4ckout em 11/03/2019 - 09:56h
Sem dúvidas o Universo Linux é sensacional e principalmente por ter uma comunidade tão viva, unida e dinâmica.
Usei o Windows por muito tempo e estou totalmente motivado a algum dia, contribuir com minhas experiências no Linux com todos aqui, no Viva o Linux.
Pode parecer simples, mas agradeço pelo esforço de todos por manter esse fórum rico como está, pois verdadeiramente é um grande refúgio para novos tripulantes.
[26] Comentário enviado por xerxeslins em 11/03/2019 - 10:19h
[25] Comentário enviado por bl4ckout em 11/03/2019 - 09:56h
Sem dúvidas o Universo Linux é sensacional e principalmente por ter uma comunidade tão viva, unida e dinâmica.
Usei o Windows por muito tempo e estou totalmente motivado a algum dia, contribuir com minhas experiências no Linux com todos aqui, no Viva o Linux.
Pode parecer simples, mas agradeço pelo esforço de todos por manter esse fórum rico como está, pois verdadeiramente é um grande refúgio para novos tripulantes.