XCOPY аркылуу Linux сервери аркылуу көлөмдөрдү сактоо тутумдарына көчүрүү

Бир маалымат сактоо тутумунун (DSS) ичинде көлөмдүн толук көчүрмөсүн алуу керек болот, сүрөт, клон эмес, толук көлөм. Бирок сактоо системасы муну өз каражаттарын колдонуу менен ички ишке ашырууга дайыма эле жол бербейт. Кыязы, бир гана вариант сервер аркылуу көчүрүү болуп саналат, бирок бул учурда маалыматтардын бардык көлөмү сервердин өзү аркылуу, тармактан сактоо тутумуна жана сактоо портторуна, бардык бул компоненттерди жүктөйт. Бирок SCSI буйруктары бар, алар сизге сактоо тутумунун ичинде бардыгын жасоого мүмкүндүк берет жана эгер сиздин тутумуңуз VMwareден VAAI колдосо, анда XCOPY (EXTENDED COPY) буйругу дээрлик 100% колдоого алынат, ал массивге эмнени жана Процесс серверин жана тармакты катыштырбастан, кайда көчүрүү керек.

Баары жөнөкөй болушу керек окшойт, бирок мен дароо эч кандай даяр скрипт таба алган жокмун, ошондуктан дөңгөлөктү кайра ойлоп табууга туура келди. Server OS үчүн 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

Келгиле, бир аз текшерип көрөлү! Кичинекей эле, 1ТБ файл тез арада түзүлүп, 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

Ошол учурда сактоо тутумунда эмне болуп жаткан:

XCOPY аркылуу Linux сервери аркылуу көлөмдөрдү сактоо тутумдарына көчүрүү
Келгиле, 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#

Баары жакшы болду, бирок сынап көрүңүз жана өзүңүздүн тобокелиңиз менен колдонуңуз! Булак көлөмү катары, башталгычтар үчүн сүрөткө тартуу жакшы.

Source: www.habr.com

Комментарий кошуу