# assume the mirror id will be 1, 2, and 3
declare -A checksums
- checksums[1]=$(md5sum $tf | cut -f 1 -d' ')
- checksums[2]=$(md5sum $tf2 | cut -f 1 -d' ')
- checksums[3]=$(md5sum $tf3 | cut -f 1 -d' ')
+ checksums[1]=$(cat $tf | md5sum)
+ checksums[2]=$(cat $tf2 | md5sum)
+ checksums[3]=$(cat $tf3 | md5sum)
printf '%s\n' "${checksums[@]}"
local sum
for i in ${mirror_array[@]}; do
- sum=$(mirror_io dump -i $i $tf | md5sum | cut -f 1 -d' ')
+ sum=$($LFS mirror dump -N $i $tf | md5sum)
[ "$sum" = "${checksums[$i]}" ] ||
error "$i: mismatch: \'${checksums[$i]}\' vs. \'$sum\'"
done
# verify copying is successful by checking checksums
remount_client $MOUNT
for i in ${mirror_array[@]}; do
- sum=$(mirror_io dump -i $i $tf | md5sum | cut -f 1 -d' ')
+ sum=$($LFS mirror dump -N $i $tf | md5sum)
[ "$sum" = "${checksums[1]}" ] ||
error "$i: mismatch checksum after copy"
done
local fsize=$((RANDOM << 8 + 1048576))
$TRUNCATE $ref $fsize
- local ref_cksum=$(md5sum $ref | cut -f 1 -d' ')
+ local ref_cksum=$(cat $ref | md5sum)
# case 1: verify write to mirrored file & resync work
cp $ref $tf || error "copy from $ref to $f error"
verify_flr_state $tf "wp"
- local file_cksum=$(md5sum $tf | cut -f 1 -d' ')
+ local file_cksum=$(cat $tf | md5sum)
[ "$file_cksum" = "$ref_cksum" ] || error "write failed, cksum mismatch"
get_mirror_ids $tf
local valid_mirror stale_mirror id mirror_cksum
for id in "${mirror_array[@]}"; do
- mirror_cksum=$(mirror_io dump -i $id $tf |
- md5sum | cut -f 1 -d' ')
+ mirror_cksum=$($LFS mirror dump -N $id $tf | md5sum)
[ "$ref_cksum" == "$mirror_cksum" ] &&
{ valid_mirror=$id; continue; }
mirror_io resync $tf || error "resync failed"
verify_flr_state $tf "ro"
- mirror_cksum=$(mirror_io dump -i $stale_mirror $tf |
- md5sum | cut -f 1 -d' ')
+ mirror_cksum=$($LFS mirror dump -N $stale_mirror $tf | md5sum)
[ "$file_cksum" = "$ref_cksum" ] || error "resync failed"
# case 2: inject an error to make mirror_io exit after changing
dd if=/dev/urandom of=$tf-1 bs=1M count=4 conv=notrunc ||
error "writing $tf-1 failed"
- local sum0=$(cat $tf-1 | md5sum | cut -f 1 -d' ')
+ local sum0=$(cat $tf-1 | md5sum)
echo " **verify files be WRITE_PENDING"
verify_flr_state $tf "wp"
$LFS mirror resync $tf $tf-1 || error "mirror resync $tf $tf-1 failed"
echo " **verify $tf-1 data consistency in all mirrors"
- local sum
for i in 1 2 3; do
- sum=$(mirror_io dump -i $i $tf-1 | md5sum | cut -f 1 -d' ')
- [ "$sum" = "$sum0" ] ||
- error "$i: mismatch: $sum vs. $sum0"
+ local sum=$($LFS mirror dump -N$i $tf-1 | md5sum)
+ [[ "$sum" = "$sum0" ]] ||
+ error "$tf-1.$i: checksum mismatch: $sum != $sum0"
done
echo " **verify files be RDONLY"
mirror_io resync $tf
get_mirror_ids $tf
- local csum=$(mirror_io dump -i ${mirror_array[0]} $tf | md5sum)
+ local csum=$($LFS mirror dump -N ${mirror_array[0]} $tf | md5sum)
for id in ${mirror_array[@]:1}; do
- [ "$(mirror_io dump -i $id $tf | md5sum)" = "$csum" ] ||
+ [ "$($LFS mirror dump -N $id $tf | md5sum)" = "$csum" ] ||
error "checksum error for mirror $id"
done
}
run_test 202 "lfs setstripe --add-component wide striping"
+test_203() {
+ [[ $OSTCOUNT -lt 2 ]] && skip "need >= 2 OSTs" && return
+
+ local tf=$DIR/$tfile
+
+ #create 2 mirrors
+ $LFS mirror create -N2 -c1 $tf || error "create FLR file $tf"
+ #delete first mirror
+ $LFS mirror split --mirror-id=1 -d $tf || error "delete first mirror"
+
+ $LFS getstripe $tf
+ local old_id=$($LFS getstripe --mirror-id=2 -I $tf)
+ local count=$($LFS getstripe --mirror-id=2 -c $tf) ||
+ error "getstripe count of mirror 2"
+ [[ x$count = x1 ]] || error "mirror 2 stripe count $count is not 1"
+
+ #extend a mirror with 2 OSTs
+ $LFS mirror extend -N -c2 $tf || error "extend mirror"
+ $LFS getstripe $tf
+
+ local new_id=$($LFS getstripe --mirror-id=2 -I $tf)
+ count=$($LFS getstripe --mirror-id=2 -c $tf) ||
+ error "getstripe count of mirror 2"
+ [[ x$oldid = x$newid ]] ||
+ error "mirror 2 changed ID from $old_id to $new_id"
+ [[ x$count = x1 ]] || error "mirror 2 stripe count $count is not 1"
+
+ count=$($LFS getstripe --mirror-id=3 -c $tf) ||
+ error "getstripe count of mirror 3"
+ [[ x$count = x2 ]] || error "mirror 3 stripe count $count is not 2"
+}
+run_test 203 "mirror file preserve mirror ID"
+
complete $SECONDS
check_and_cleanup_lustre
exit_status