Eu tenho 10 discos com 8 TB cada um em um RAID6 de hardware (assim, 8 discos de dados + 2 paridade). Seguindo a resposta de uma pergunta muito semelhante , esperava uma detecção automática de todos os parâmetros necessários. No entanto, ao criar o sistema de arquivos XFS no final, recebi
# mkfs.xfs /dev/vgdata/lvscratch
meta-data=/dev/vgdata/lvscratch isize=256 agcount=40, agsize=268435455 blks
= sectsz=4096 attr=2, projid32bit=1
= crc=0 finobt=0
data = bsize=4096 blocks=10737418200, imaxpct=5
= sunit=0 swidth=0 blks
naming =version 2 bsize=4096 ascii-ci=0 ftype=0
log =internal log bsize=4096 blocks=521728, version=2
= sectsz=4096 sunit=1 blks, lazy-count=1
realtime =none extsz=4096 blocks=0, rtextents=0
Parece que as faixas não foram usadas. Devido aos diferentes termos que encontrei em sites diferentes (tamanho da faixa, tamanho da faixa, parte da faixa, ...), gostaria de perguntar se obtive os parâmetros manuais corretamente.
O RAID 6 foi configurado com um tamanho de faixa de 256 KB:
# ./storcli64 /c0/v1 show all | grep Strip
Strip Size = 256 KB
Assim, o tamanho da faixa é 8 * 256 KB = 2048 KB = 2 MB. Isso está correto? De acordo com isso (e se eu entendi direito), o pvcreate
tem que usar o tamanho da faixa (ou parte) como argumento para dataalignment
:
# pvcreate --dataalignment 256K /dev/sdb
Physical volume "/dev/sdb" successfully created
Observe que eu usei todo o dispositivo RAID sem partições. Agora um
# vgcreate vgdata /dev/sdb
Volume group "vgdata" successfully created
com um tamanho padrão de PE de 4 MB deve ser bom porque é um múltiplo do tamanho da faixa de 2 MB. Corrigir?
Agora, uma parte do vgroup é atribuída a um volume lógico:
# lvcreate -L 40T vgdata -n lvscratch
Logical volume "lvscratch" created.
Finalmente, o sistema de arquivos é criado, mas agora com os argumentos corretos (tamanho da faixa de 2 MB, largura da faixa de 8):
# mkfs.xfs -d su=2048k,sw=8 /dev/vgdata/lvscratch
meta-data=/dev/vgdata/lvscratch isize=256 agcount=41, agsize=268434944 blks
= sectsz=4096 attr=2, projid32bit=1
= crc=0 finobt=0
data = bsize=4096 blocks=10737418240, imaxpct=5
= sunit=512 swidth=4096 blks
naming =version 2 bsize=4096 ascii-ci=0 ftype=0
log =internal log bsize=4096 blocks=521728, version=2
= sectsz=4096 sunit=1 blks, lazy-count=1
realtime =none extsz=4096 blocks=0, rtextents=0
Essa abordagem está correta? Há algo a ter em mente para uma extensão do volume lógico ou do grupo de volumes? Suponho que, se o grupo de volumes for estendido com outro sistema RAID6, o tamanho da faixa deverá ser igual ao atual RAID6.
EDIT : Minha confusão parece basear-se principalmente no uso diferente dos termos conectados ao stripe. O fabricante do meu controlador RAID, LSI ou Avago, define os termos da seguinte maneira :
Largura da faixa
Largura da faixa é o número de unidades envolvidas em um grupo de unidades em que a faixa é implementada. Por exemplo, um grupo de unidades de quatro discos com faixas de disco tem uma largura de faixa de quatro.
Tamanho da faixa
O tamanho da faixa é o comprimento dos segmentos de dados intercalados que o controlador RAID grava em várias unidades, sem incluir as unidades de paridade. Por exemplo, considere uma faixa que contém 64 KB de espaço em disco e 16 KB de dados que residem em cada disco na faixa. Nesse caso, o tamanho da faixa é de 64 KB e o tamanho da faixa é de 16 KB.
Tamanho da tira
O tamanho da faixa é a parte de uma faixa que reside em uma única unidade.
A Wikipedia (e a IBM ) parecem usar outras definições:
Os segmentos de dados sequenciais gravados ou lidos a partir de um disco antes da operação continuar no próximo disco são geralmente chamados de chunks, strides ou stripe units, enquanto seus grupos lógicos que formam operações com uma única faixa são chamados strips ou stripes. A quantidade de dados em um pedaço (unidade de faixa), geralmente denominada em bytes, é chamada de tamanho do pedaço, tamanho da passada, tamanho da faixa, profundidade da faixa ou profundidade da faixa. Às vezes, o número de discos de dados na matriz é chamado de largura da faixa, mas também pode se referir à quantidade de dados em uma faixa.
A quantidade de dados em uma etapa multiplicada pelo número de discos de dados na matriz (ou seja, profundidade da faixa vezes a largura da faixa, que na analogia geométrica renderia uma área) às vezes é chamada de tamanho ou largura da faixa. A distribuição ampla ocorre quando pedaços de dados são espalhados por várias matrizes, possivelmente todas as unidades do sistema. A distribuição estreita ocorre quando os blocos de dados são espalhados pelas unidades em uma única matriz.
Mesmo no texto da Wikipedia, o tamanho da faixa acima é usado com dois significados diferentes. No entanto, suponho que agora, ao criar o sistema de arquivos xfs, o tamanho de um único bloco armazenado em uma única unidade precise ser fornecido como argumento para su. Isso deve estar mkfs.xfs -d su=256k,sw=8
no comando acima. Corrigir?
pvcreate
's'--dataalignment
?vgcreate
deve ser o mesmo ou um múltiplo disso.O volume lógico não foi distribuído (-i 8 -I 256k), portanto, o sistema de arquivos xfs não vê nada além de um único disco contíguo
Pergunta antiga, mas salve outros usuários do mesmo erro.
fonte