XCOPY-ի միջոցով ծավալների պատճենում պահեստավորման համակարգերում Linux սերվերի միջոցով

Դա տեղի է ունենում, որ դուք պետք է ստանաք ծավալի ամբողջական պատճենը մեկ տվյալների պահպանման համակարգի (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

Ինչ էր կատարվում պահեստավորման համակարգում այդ պահին.

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

Добавить комментарий