Kopírovanie zväzkov do úložných systémov cez server Linux pomocou XCOPY

Stáva sa, že potrebujete získať úplnú kópiu zväzku v rámci jedného systému na ukladanie údajov (DSS), nie snímku, klon, ale celý zväzok. Systém skladovania však nie vždy umožňuje, aby to bolo vykonané interne pomocou vlastných prostriedkov. Zdá sa, že jedinou možnosťou je kopírovanie cez server, ale v tomto prípade sa celý objem dát presunie cez samotný server, sieť do úložného systému a úložné porty, pričom sa načítajú všetky tieto komponenty. Existujú však príkazy SCSI, ktoré vám umožnia robiť všetko v rámci samotného úložného systému, a ak váš systém podporuje VAAI od VMware, potom je takmer na 100% podporovaný príkaz XCOPY (EXTENDED COPY), ktorý poliu povie, čo a kam kopírovať, bez zapojenia procesného servera a siete.

Zdá sa, že všetko by malo byť jednoduché, ale nemohol som okamžite nájsť žiadne hotové skripty, takže som musel znova vynájsť koleso. Ako operačný systém servera bol vybraný Linux a ako nástroj na kopírovanie bol zvolený príkaz ddpt (http://sg.danny.cz/sg/ddpt.html). Pomocou tejto kombinácie môžete kopírovať ľubovoľné zväzky z ľubovoľného operačného systému, pretože kopírovanie prebieha blok po bloku na strane úložného systému. Keďže je potrebné kopírovať blok po bloku a počet blokov sa musí počítať, na spočítanie počtu takýchto iterácií bol použitý príkaz blockdev. Maximálna veľkosť bloku bola získaná experimentálne; ddpt v skutočnosti nepracoval s veľkým blokom. Výsledkom bol nasledujúci pomerne jednoduchý skript:

#!/bin/bash
# first parameter = input device
# second parameter = output device
# device size must be the same
# changing bs variable can reduce speed, max speed should be at bs=32768. 32768 is max setting, lower settings should be calculated dividing by 2

set -o nounset
bs=32768
s=`blockdev --getsz $1`
i=0
while [ $i -le $s ]
do
ddpt of=$2 bs=512 oflag=xcopy,direct if=$1 iflag=xcopy,direct count=$bs verbose=-1 skip=$i seek=$i
i=$(( $i+$bs ))
done

Urobme si malú kontrolu! No, ako malý, 1TB súbor nebol rýchlo vytvorený a skontrolovaný md5sum :)

root@sales-demo-05:/home/vasilyk# blockdev --getsz /dev/mapper/mpathfs
2516582400
root@sales-demo-05:/home/vasilyk# blockdev --getsz /dev/mapper/mpathfr
2516582400
root@sales-demo-05:/home/vasilyk# mount /dev/mapper/mpathfs /xcopy_source/
mount: /xcopy_source: wrong fs type, bad option, bad superblock on /dev/mapper/mpathfs, missing codepage or helper program, or other error.
root@sales-demo-05:/home/vasilyk# mkfs /dev/mapper/mpathfs
mke2fs 1.44.1 (24-Mar-2018)
Discarding device blocks: done
Creating filesystem with 314572800 4k blocks and 78643200 inodes
Filesystem UUID: bed3ea00-c181-4b4e-b52e-d9bb498be756
Superblock backups stored on blocks:
        32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208,
        4096000, 7962624, 11239424, 20480000, 23887872, 71663616, 78675968,
        102400000, 214990848

Allocating group tables: done
Writing inode tables: done
Writing superblocks and filesystem accounting information: done

root@sales-demo-05:/home/vasilyk# mount /dev/mapper/mpathfs /xcopy_source/
root@sales-demo-05:/home/vasilyk# ls -l /xcopy_source/
total 16
drwx------ 2 root root 16384 Aug 19 15:35 lost+found
root@sales-demo-05:/home/vasilyk# head -c 1T </dev/urandom > /xcopy_source/1TB_file
root@sales-demo-05:/home/vasilyk# ls -l /xcopy_source/
total 1074791444
-rw-r--r-- 1 root root 1099511627776 Aug 19 17:25 1TB_file
drwx------ 2 root root         16384 Aug 19 15:35 lost+found
root@sales-demo-05:/home/vasilyk# umount /xcopy_source
root@sales-demo-05:/home/vasilyk# mount /dev/mapper/mpathfr /xcopy_dest/
mount: /xcopy_dest: wrong fs type, bad option, bad superblock on /dev/mapper/mpathfr, missing codepage or helper program, or other error.
root@sales-demo-05:/home/vasilyk# cat xcopy.sh
#!/bin/bash
# first parameter = input device
# second parameter = output device
# device size must be the same
# changing bs variable can reduce speed, max speed should be at bs=32768. 32768 is max setting, lower settings should be calculated dividing by 2

bs=32768
s=`blockdev --getsz $1`
i=0
while [ $i -le $s ]
do
ddpt of=$2 bs=512 oflag=xcopy,direct if=$1 iflag=xcopy,direct count=$bs verbose=-1 skip=$i seek=$i
i=$(( $i+$bs ))
done
root@sales-demo-05:/home/vasilyk# time ./xcopy.sh /dev/mapper/mpathfs /dev/mapper/mpathfr
real    11m30.878s
user    2m3.000s
sys     1m11.657s

Čo sa v tej chvíli dialo na úložnom systéme:

Kopírovanie zväzkov do úložných systémov cez server Linux pomocou XCOPY
Pokračujme v Linuxe.

root@sales-demo-05:/home/vasilyk# mount /dev/mapper/mpathfr /xcopy_dest/
root@sales-demo-05:/home/vasilyk# ls -l /xcopy_dest/
total 1074791444
-rw-r--r-- 1 root root 1099511627776 Aug 19 17:25 1TB_file
drwx------ 2 root root         16384 Aug 19 15:35 lost+found
root@sales-demo-05:/home/vasilyk# mount /dev/mapper/mpathfs /xcopy_source/
root@sales-demo-05:/home/vasilyk# md5sum /xcopy_source/1TB_file
53dc6dfdfc89f099c0d5177c652b5764  /xcopy_source/1TB_file
root@sales-demo-05:/home/vasilyk# md5sum /xcopy_dest/1TB_file
53dc6dfdfc89f099c0d5177c652b5764  /xcopy_dest/1TB_file
root@sales-demo-05:/home/vasilyk#

Všetko fungovalo, ale testovanie a používanie na vlastné riziko! Ako zdrojový zväzok je pre začiatok lepšie robiť snímky.

Zdroj: hab.com

Pridať komentár