Копиране на томове в системи за съхранение чрез Linux сървър с помощта на XCOPY

Случва се да трябва да получите пълно копие на том в рамките на една система за съхранение на данни (DSS), а не моментна снимка, клонинг, а пълен том. Но системата за съхранение не винаги позволява това да се направи вътрешно със собствени средства. Изглежда, че единствената възможност е да копирате през сървъра, но в този случай целият обем от данни ще бъде прекаран през самия сървър, мрежата към системата за съхранение и портовете за съхранение, зареждайки всички тези компоненти. Но има SCSI команди, които могат да ви позволят да правите всичко в самата система за съхранение и ако вашата система поддържа VAAI от VMware, тогава е почти 100%, че се поддържа командата XCOPY (EXTENDED COPY), която казва на масива какво и къде да копирате, без да включвате процес сървър и мрежа.

Изглежда, че всичко трябва да е просто, но не можах да намеря готови скриптове веднага, така че трябваше да преоткрия колелото. Linux беше избран за сървърна операционна система и командата ddpt (http://sg.danny.cz/sg/ddpt.html) беше избрана като инструмент за копиране. Използвайки тази комбинация, можете да копирате всякакви томове от всяка ОС, тъй като копирането се извършва блок по блок от страна на системата за съхранение. Тъй като е необходимо да се копира блок по блок и броят на блоковете трябва да се преброи, командата blockdev беше използвана за преброяване на броя на такива повторения. Максималният размер на блока е получен експериментално; ddpt всъщност не работи с голям блок. Резултатът беше следният доста прост скрипт:

#!/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

Нека направим малка проверка! Е, като малък, файл от 1TB не беше бързо създаден и проверен от 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

Какво се случва в системата за съхранение в този момент:

Копиране на томове в системи за съхранение чрез Linux сървър с помощта на XCOPY
Да продължим с Linux.

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#

Всичко се получи, но тествайте и използвайте на свой собствен риск! Като изходен обем е по-добре да направите моментни снимки за начало.

Източник: www.habr.com

Добавяне на нов коментар