Ich habe eine iSCSI-Festplatte bei/dev/rdsk/c5t6d0
Ich habe eine Partition (Slice mit UEFI-Label) erstellt unter:/dev/rdsk/c5t6d0s0
Nun schreibe ich einige Daten in das Slice:
echo "xyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyxy" >/text
dd if=/text of=/dev/dsk/c5t6d0s0
Wenn ich den Festplatteninhalt dumpe, sehe ich das UEFI-Label und auch meine Daten beim Offset 0x5000:
dd if=/dev/rdsk/c5t6d0 bs=512 | xxd
0000000: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000040: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000050: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000060: 0000 0000 0000 0000 0000 0000 0000 0000 ................
...
0000070: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000190: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00001a0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00001b0: 0000 0000 0000 0000 0eb5 7760 0000 00ff ..........w`....
00001c0: ffff eeff ffff 0100 0000 ff3f 0300 0000 ...........?....
00001d0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00001e0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00001f0: 0000 0000 0000 0000 0000 0000 0000 55aa ..............U.
0000200: 4546 4920 5041 5254 0000 0100 5c00 0000 EFI PART....\...
0000210: 7187 d278 0000 0000 0100 0000 0000 0000 q..x............
0000220: ff3f 0300 0000 0000 2200 0000 0000 0000 .?......".......
0000230: de3f 0300 0000 0000 fd59 3d67 51a0 4d13 .?.......Y=gQ.M.
0000240: abdd a5e8 8251 c7ac 0200 0000 0000 0000 .....Q..........
0000250: 8000 0000 8000 0000 7e8c 8e06 0000 0000 ........~.......
0000260: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000270: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000280: 0000 0000 0000 0000 0000 0000 0000 0000 ................
...
0005000: 7879 7879 7879 7879 7879 7879 7879 7879 xyxyxyxyxyxyxyxy
0005010: 7879 7879 7879 7879 7879 7879 7879 7879 xyxyxyxyxyxyxyxy
0005020: 7879 7879 7879 7879 7879 7879 7879 7879 xyxyxyxyxyxyxyxy
0005030: 7879 7879 7879 7879 7879 7879 0ab6 db6d xyxyxyxyxyxy...m
0005040: 6db6 db6d 6db6 db6d 6db6 db6d 6db6 db6d m..mm..mm..mm..m
0005050: 6db6 db6d 6db6 db6d 6db6 db6d 6db6 db6d m..mm..mm..mm..m
0005060: 6db6 db6d 6db6 db6d 6db6 db6d 6db6 db6d m..mm..mm..mm..m
0005070: 6db6 db6d 6db6 db6d 6db6 db6d 6db6 db6d m..mm..mm..mm..m
0005080: 6db6 db6d 6db6 db6d 6db6 db6d 6db6 db6d m..mm..mm..mm..m
0005090: 6db6 db6d 6db6 db6d 6db6 db6d 6db6 db6d m..mm..mm..mm..m
Aber wenn ich den gleichen Dump auf der Speicherseite (iSCSI-Ziel) mache, sehe ich meine geschriebenen Daten nicht! Ichabschaltendie SPARC/Solaris-Maschine undvoilà!die Daten sind nun da.
Wie kann das sein? Speichert Solaris meine Daten im Cache? Wie kann ich das deaktivieren?
Hinweis 1: Ich habe versucht, es zu verwenden sync
, aber es hat nicht geholfen. Außerdem bezieht es sich auf Dateien in einem Dateisystem, das ich in meinem Szenario nicht habe.
Hinweis 2: Mein Rechner ist ein T5220 UltraSPARC T2 Server mit Solaris 11.3
Hinweis 3: „Speicher“ ist ein Ubuntu-Server mit iSCSI-Ziel auf einem lokalen Festplatten-Backing-Store.
Antwort1
Sie schreiben auf das Blockgerät ( dsk
), das gepuffert ist. Wenn Sie den Puffer umgehen möchten, können Sie direkt auf das Rohgerät ( rdsk
, sieheWas sind Zeichen-Sonderdateien und Block-Sonderdateien in einem Unix-System?) durch Ausführen von:
dd if=/text of=/dev/rdsk/c5t6d0s0
Damit dies gelingt, müsste Ihre /text
Datei allerdings wahrscheinlich genau ein Vielfaches einer Blockgröße groß sein dd
.
Alternativ können Sie weiterhin das Zeichengerät verwenden, aber dd
die Ausgabe synchronisieren:
dd if=/text of=/dev/dsk/c5t6d0s0 conv=sync
oder, wenn Sie Ausgabedatensätze mit fester Breite wünschen:
dd if=/text of=/dev/rdsk/c5t6d0s0 cbs=512 conv=sync,block