a primeira entrada da minha tabela de partição é:
$ sudo hexdump -Cv -n 16 -s 446 /dev/sda
000001be 80 01 01 00 83 fe ff ff 3f 00 00 00 81 1c 20 03 |........?..... .|
( -Cv descreve o formato de saída, -n 16 pede 16 bytes e -s 446 ignora os primeiros 446 bytes)
Você pode ver que minha primeira partição é uma partição primária do Linux e que essa partição começa no setor 63 (consulte, por exemplo, [ aqui] [1] para a estrutura da tabela de partição).
Eu esperaria que, exceto nos primeiros 63 setores e nas outras partições, / dev / sda1 e / dev / sda sejam exatamente iguais.
Mas não é esse o caso, o setor nº 2 de / dev / sda1 não é exatamente o mesmo que o setor nº 65 de / dev / sda (mas eles são muito semelhantes, apenas 16 bytes são diferentes):
$ sudo hexdump -Cv -n 512 -s 65b /dev/sda
00008200 00 20 19 00 90 03 64 00 2d 00 05 00 5a 2f 56 00 |. ....d.-...Z/V.|
00008210 b6 b1 16 00 00 00 00 00 02 00 00 00 02 00 00 00 |................|
00008220 00 80 00 00 00 80 00 00 00 20 00 00 d8 38 ee 4c |......... ...8.L|
00008230 9a 01 ef 4c 05 00 24 00 53 ef 01 00 01 00 00 00 |...L..$.S.......|
00008240 59 23 e9 4c 00 4e ed 00 00 00 00 00 01 00 00 00 |Y#.L.N..........|
00008250 00 00 00 00 0b 00 00 00 00 01 00 00 3c 00 00 00 |............<...|
00008260 42 02 00 00 7b 00 00 00 85 23 eb f2 71 67 44 f5 |B...{....#..qgD.|
00008270 bb 8f 6f f2 3a 59 ff 4d 55 62 75 6e 74 75 00 00 |..o.:Y.MUbuntu..|
00008280 00 00 00 00 00 00 00 00 2f 75 62 75 6e 74 75 00 |......../ubuntu.|
00008290 d8 3c df 5d 00 88 ff ff 52 d0 ef 1d 00 00 00 00 |.<.]....R.......|
000082a0 c0 40 51 b6 00 88 ff ff 00 4e c8 bb 00 88 ff ff |[email protected]......|
000082b0 c0 f6 86 b8 00 88 ff ff 30 2e 0d a0 ff ff ff ff |........0.......|
000082c0 38 3d df 5d 00 88 ff ff 00 00 00 00 00 00 fe 03 |8=.]............|
000082d0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
000082e0 08 00 00 00 00 00 00 00 00 00 00 00 8a 53 d3 0e |.............S..|
000082f0 7c 7a 43 e4 8b fb ca e0 72 b7 fa c8 01 01 00 00 ||zC.....r.......|
00008300 00 00 00 00 00 00 00 00 16 4c 47 4b 0a f3 03 00 |.........LGK....|
00008310 04 00 00 00 00 00 00 00 00 00 00 00 fe 7f 00 00 |................|
00008320 24 b7 0c 00 fe 7f 00 00 01 00 00 00 22 37 0d 00 |$..........."7..|
00008330 ff 7f 00 00 01 00 00 00 23 37 0d 00 00 00 00 00 |........#7......|
00008340 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 08 |................|
00008350 00 00 00 00 00 00 00 00 00 00 00 00 1c 00 1c 00 |................|
00008360 01 00 00 00 e9 7f 00 00 00 00 00 00 00 00 00 00 |................|
00008370 00 00 00 00 04 00 00 00 9f 7d bb 00 00 00 00 00 |.........}......|
00008380 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
00008390 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
000083a0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
000083b0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
000083c0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
000083d0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
000083e0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
000083f0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
versus
$ sudo hexdump -Cv -n 512 -s 2b /dev/sda1
00000400 00 20 19 00 90 03 64 00 2d 00 05 00 5a 2f 56 00 |. ....d.-...Z/V.|
00000410 b6 b1 16 00 00 00 00 00 02 00 00 00 02 00 00 00 |................|
00000420 00 80 00 00 00 80 00 00 00 20 00 00 df 76 ef 4c |......... ...v.L|
00000430 df 76 ef 4c 06 00 24 00 53 ef 01 00 01 00 00 00 |.v.L..$.S.......|
00000440 59 23 e9 4c 00 4e ed 00 00 00 00 00 01 00 00 00 |Y#.L.N..........|
00000450 0
linux
partitioning
Guillaume Brunerie
fonte
fonte
Respostas:
Boa descoberta, pois também pude reproduzir esse efeito no meu sistema. No meu site, isso acontece em / dev / hda, portanto, não há problema de SCSI.
Acho
whitequark
certo que seja um problema de cache. Aqui está a minha interpretação do que aconteceu no seu site ( observe que não tenho certeza de que minha explicação esteja correta ):/ dev / sda1 está em uso. Portanto, "sync" atualiza o superbloco toda vez que o diário é liberado (ou semelhante). Portanto, o disco / dev / sda1 é alterado.
No entanto, o kernel não usa um cache combinado para / dev / sda e / dev / sda1. Em vez disso, os dois "arquivos" são armazenados por si só. A atualização de / dev / sda1 (sincronização) para isso não invalida o cache de / dev / sda. Portanto, a leitura de / dev / sda mostra o valor antigo do cache (portanto, o cache está fora de sincronia com o disco rígido) enquanto / dev / sda1 mostra os valores corretos (novos).
Aqui está a situação vista do meu lado. Eu vim aqui tendo feito alguns despejos antes no / dev / hda, por isso já havia armazenado em cache alguns dados antigos:
Enquanto / dev / hda não mostra nenhuma atualização, / dev / hda2 mostra algumas alterações. Mas quando eu libero os caches e tento novamente, tudo se mostra igual:
Nota curta sobre como reproduzir:
fdisk -u -l
para descobrir onde a partição é iniciada. Ao meu lado, é 1975995hdparm
linha para sua unidadefonte
Depois de fazer testes semelhantes, não tenho diferenças. Pode ser que esse setor específico tenha sido escrito entre cada despejo.
O comando a seguir compara os primeiros ~ 48MB do mesmo setor extraído de / dev / sda e / dev / sda1:
$ diff <(sudo hexdump -Cv -n $((512*100000)) -s 0x7e00 /dev/sda | awk '{$1=""}1' ) <(sudo hexdump -Cv -n $((512*100000)) /dev/sda1 | awk '{$1=""}1' )
Onde 0x7e00 é o deslocamento da primeira partição.
fonte