XCOPY を使用した Linux サーバー経由のストレージ システムへのボリュームのコピー

スナップショットやクローンではなく、100 つのデータ ストレージ システム (DSS) 内のボリュームのフル コピーを取得する必要がある場合があります。 ただし、ストレージ システムでは、独自の手段を使用してこれを内部的に実行できるとは限りません。 唯一のオプションはサーバーを介してコピーすることのようですが、この場合、データのボリューム全体がサーバー自体、ネットワークを介してストレージ システムとストレージ ポートに送られ、これらすべてのコンポーネントがロードされます。 ただし、ストレージ システム自体内ですべてを実行できる SCSI コマンドがあり、システムが VMware の VAAI をサポートしている場合は、ほぼ XNUMX% の確率で XCOPY (EXTENDED COPY) コマンドがサポートされています。プロセスサーバーやネットワークを介さずにコピーする場所。

すべてがシンプルであるはずのように思えますが、既製のスクリプトがすぐに見つからなかったため、車輪を再発明する必要がありました。 サーバOSにはLinuxを選択し、コピーツールにはddptコマンド(http://sg.danny.cz/sg/ddpt.html)を選択しました。 この組み合わせを使用すると、ストレージ システム側でコピーがブロックごとに行われるため、任意の OS から任意のボリュームをコピーできます。 ブロックごとにコピーする必要があり、ブロック数をカウントする必要があるため、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#

すべてうまくいきましたが、テストと使用は自己責任で行ってください。 ソース ボリュームとしては、まずスナップショットを作成することをお勧めします。

出所: habr.com

コメントを追加します