2017-07-20 22:26:42 +00:00
|
|
|
#!/usr/bin/env bash
|
2017-02-15 17:06:14 +00:00
|
|
|
|
|
|
|
set -ex
|
|
|
|
|
2018-02-20 09:42:52 +00:00
|
|
|
export RBD_FORCE_ALLOW_V1=1
|
|
|
|
|
2017-02-15 17:06:14 +00:00
|
|
|
function fill_image() {
|
|
|
|
local spec=$1
|
|
|
|
|
|
|
|
local dev
|
|
|
|
dev=$(sudo rbd map $spec)
|
|
|
|
xfs_io -c "pwrite -b $OBJECT_SIZE -S 0x78 -W 0 $IMAGE_SIZE" $dev
|
|
|
|
sudo rbd unmap $dev
|
|
|
|
}
|
|
|
|
|
|
|
|
function create_clones() {
|
|
|
|
local spec=$1
|
|
|
|
|
|
|
|
rbd snap create $spec@snap
|
|
|
|
rbd snap protect $spec@snap
|
|
|
|
|
|
|
|
local pool=${spec%/*} # pool/image is assumed
|
|
|
|
local image=${spec#*/}
|
|
|
|
local child_pool
|
|
|
|
for child_pool in $pool clonesonly; do
|
|
|
|
rbd clone $spec@snap $child_pool/$pool-$image-clone1
|
|
|
|
rbd clone $spec@snap --data-pool repdata $child_pool/$pool-$image-clone2
|
|
|
|
rbd clone $spec@snap --data-pool ecdata $child_pool/$pool-$image-clone3
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
function trigger_copyup() {
|
|
|
|
local spec=$1
|
|
|
|
|
|
|
|
local dev
|
|
|
|
dev=$(sudo rbd map $spec)
|
|
|
|
local i
|
|
|
|
{
|
|
|
|
for ((i = 0; i < $NUM_OBJECTS; i++)); do
|
|
|
|
echo pwrite -b $OBJECT_SIZE -S 0x59 $((i * OBJECT_SIZE + OBJECT_SIZE / 2)) $((OBJECT_SIZE / 2))
|
|
|
|
done
|
|
|
|
echo fsync
|
|
|
|
echo quit
|
|
|
|
} | xfs_io $dev
|
|
|
|
sudo rbd unmap $dev
|
|
|
|
}
|
|
|
|
|
|
|
|
function compare() {
|
|
|
|
local spec=$1
|
|
|
|
local object=$2
|
|
|
|
|
|
|
|
local dev
|
|
|
|
dev=$(sudo rbd map $spec)
|
|
|
|
local i
|
|
|
|
for ((i = 0; i < $NUM_OBJECTS; i++)); do
|
|
|
|
dd if=$dev bs=$OBJECT_SIZE count=1 skip=$i | cmp $object -
|
|
|
|
done
|
|
|
|
sudo rbd unmap $dev
|
|
|
|
}
|
|
|
|
|
|
|
|
function mkfs_and_mount() {
|
|
|
|
local spec=$1
|
|
|
|
|
|
|
|
local dev
|
|
|
|
dev=$(sudo rbd map $spec)
|
2019-03-25 19:58:00 +00:00
|
|
|
blkdiscard $dev
|
|
|
|
mkfs.ext4 -q -E nodiscard $dev
|
2017-02-15 17:06:14 +00:00
|
|
|
sudo mount $dev /mnt
|
|
|
|
sudo umount /mnt
|
|
|
|
sudo rbd unmap $dev
|
|
|
|
}
|
|
|
|
|
2017-06-08 13:57:59 +00:00
|
|
|
function list_HEADs() {
|
|
|
|
local pool=$1
|
|
|
|
|
|
|
|
rados -p $pool ls | while read obj; do
|
|
|
|
if rados -p $pool stat $obj >/dev/null 2>&1; then
|
|
|
|
echo $obj
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2017-02-15 17:06:14 +00:00
|
|
|
function count_data_objects() {
|
|
|
|
local spec=$1
|
|
|
|
|
|
|
|
local pool
|
|
|
|
pool=$(rbd info $spec | grep 'data_pool: ' | awk '{ print $NF }')
|
|
|
|
if [[ -z $pool ]]; then
|
|
|
|
pool=${spec%/*} # pool/image is assumed
|
|
|
|
fi
|
|
|
|
|
|
|
|
local prefix
|
|
|
|
prefix=$(rbd info $spec | grep 'block_name_prefix: ' | awk '{ print $NF }')
|
2017-06-08 13:57:59 +00:00
|
|
|
rados -p $pool ls | grep -c $prefix
|
|
|
|
}
|
|
|
|
|
|
|
|
function get_num_clones() {
|
|
|
|
local pool=$1
|
|
|
|
|
|
|
|
rados -p $pool --format=json df |
|
2019-11-26 11:06:58 +00:00
|
|
|
python3 -c 'import sys, json; print(json.load(sys.stdin)["pools"][0]["num_object_clones"])'
|
2017-02-15 17:06:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
ceph osd pool create repdata 24 24
|
2017-06-27 01:15:57 +00:00
|
|
|
rbd pool init repdata
|
2017-06-30 18:59:39 +00:00
|
|
|
ceph osd erasure-code-profile set teuthologyprofile crush-failure-domain=osd m=1 k=2
|
2017-02-15 17:06:14 +00:00
|
|
|
ceph osd pool create ecdata 24 24 erasure teuthologyprofile
|
2017-06-27 01:15:57 +00:00
|
|
|
rbd pool init ecdata
|
2017-02-14 08:04:12 +00:00
|
|
|
ceph osd pool set ecdata allow_ec_overwrites true
|
2017-02-15 17:06:14 +00:00
|
|
|
ceph osd pool create rbdnonzero 24 24
|
2017-06-27 01:15:57 +00:00
|
|
|
rbd pool init rbdnonzero
|
2017-02-15 17:06:14 +00:00
|
|
|
ceph osd pool create clonesonly 24 24
|
2017-06-27 01:15:57 +00:00
|
|
|
rbd pool init clonesonly
|
2017-02-15 17:06:14 +00:00
|
|
|
|
|
|
|
for pool in rbd rbdnonzero; do
|
|
|
|
rbd create --size 200 --image-format 1 $pool/img0
|
|
|
|
rbd create --size 200 $pool/img1
|
|
|
|
rbd create --size 200 --data-pool repdata $pool/img2
|
|
|
|
rbd create --size 200 --data-pool ecdata $pool/img3
|
|
|
|
done
|
|
|
|
|
2019-11-26 11:06:58 +00:00
|
|
|
IMAGE_SIZE=$(rbd info --format=json img1 | python3 -c 'import sys, json; print(json.load(sys.stdin)["size"])')
|
|
|
|
OBJECT_SIZE=$(rbd info --format=json img1 | python3 -c 'import sys, json; print(json.load(sys.stdin)["object_size"])')
|
2017-02-15 17:06:14 +00:00
|
|
|
NUM_OBJECTS=$((IMAGE_SIZE / OBJECT_SIZE))
|
|
|
|
[[ $((IMAGE_SIZE % OBJECT_SIZE)) -eq 0 ]]
|
|
|
|
|
|
|
|
OBJECT_X=$(mktemp) # xxxx
|
|
|
|
xfs_io -c "pwrite -b $OBJECT_SIZE -S 0x78 0 $OBJECT_SIZE" $OBJECT_X
|
|
|
|
|
|
|
|
OBJECT_XY=$(mktemp) # xxYY
|
|
|
|
xfs_io -c "pwrite -b $OBJECT_SIZE -S 0x78 0 $((OBJECT_SIZE / 2))" \
|
|
|
|
-c "pwrite -b $OBJECT_SIZE -S 0x59 $((OBJECT_SIZE / 2)) $((OBJECT_SIZE / 2))" \
|
|
|
|
$OBJECT_XY
|
|
|
|
|
|
|
|
for pool in rbd rbdnonzero; do
|
|
|
|
for i in {0..3}; do
|
|
|
|
fill_image $pool/img$i
|
|
|
|
if [[ $i -ne 0 ]]; then
|
|
|
|
create_clones $pool/img$i
|
|
|
|
for child_pool in $pool clonesonly; do
|
|
|
|
for j in {1..3}; do
|
|
|
|
trigger_copyup $child_pool/$pool-img$i-clone$j
|
|
|
|
done
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
done
|
|
|
|
|
2017-04-18 19:20:31 +00:00
|
|
|
# rbd_directory, rbd_children, rbd_info + img0 header + ...
|
|
|
|
NUM_META_RBDS=$((3 + 1 + 3 * (1*2 + 3*2)))
|
|
|
|
# rbd_directory, rbd_children, rbd_info + ...
|
|
|
|
NUM_META_CLONESONLY=$((3 + 2 * 3 * (3*2)))
|
2017-02-15 17:06:14 +00:00
|
|
|
|
|
|
|
[[ $(rados -p rbd ls | wc -l) -eq $((NUM_META_RBDS + 5 * NUM_OBJECTS)) ]]
|
2017-04-18 19:20:31 +00:00
|
|
|
[[ $(rados -p repdata ls | wc -l) -eq $((1 + 14 * NUM_OBJECTS)) ]]
|
|
|
|
[[ $(rados -p ecdata ls | wc -l) -eq $((1 + 14 * NUM_OBJECTS)) ]]
|
2017-02-15 17:06:14 +00:00
|
|
|
[[ $(rados -p rbdnonzero ls | wc -l) -eq $((NUM_META_RBDS + 5 * NUM_OBJECTS)) ]]
|
|
|
|
[[ $(rados -p clonesonly ls | wc -l) -eq $((NUM_META_CLONESONLY + 6 * NUM_OBJECTS)) ]]
|
|
|
|
|
|
|
|
for pool in rbd rbdnonzero; do
|
|
|
|
for i in {0..3}; do
|
|
|
|
[[ $(count_data_objects $pool/img$i) -eq $NUM_OBJECTS ]]
|
|
|
|
if [[ $i -ne 0 ]]; then
|
|
|
|
for child_pool in $pool clonesonly; do
|
|
|
|
for j in {1..3}; do
|
|
|
|
[[ $(count_data_objects $child_pool/$pool-img$i-clone$j) -eq $NUM_OBJECTS ]]
|
|
|
|
done
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
done
|
|
|
|
|
2017-06-08 13:57:59 +00:00
|
|
|
[[ $(get_num_clones rbd) -eq 0 ]]
|
|
|
|
[[ $(get_num_clones repdata) -eq 0 ]]
|
|
|
|
[[ $(get_num_clones ecdata) -eq 0 ]]
|
|
|
|
[[ $(get_num_clones rbdnonzero) -eq 0 ]]
|
|
|
|
[[ $(get_num_clones clonesonly) -eq 0 ]]
|
|
|
|
|
2017-02-15 17:06:14 +00:00
|
|
|
for pool in rbd rbdnonzero; do
|
|
|
|
for i in {0..3}; do
|
|
|
|
compare $pool/img$i $OBJECT_X
|
|
|
|
mkfs_and_mount $pool/img$i
|
|
|
|
if [[ $i -ne 0 ]]; then
|
|
|
|
for child_pool in $pool clonesonly; do
|
|
|
|
for j in {1..3}; do
|
|
|
|
compare $child_pool/$pool-img$i-clone$j $OBJECT_XY
|
|
|
|
done
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
done
|
|
|
|
|
2019-03-25 19:58:00 +00:00
|
|
|
# mkfs_and_mount should discard some objects everywhere but in clonesonly
|
2017-06-08 13:57:59 +00:00
|
|
|
[[ $(list_HEADs rbd | wc -l) -lt $((NUM_META_RBDS + 5 * NUM_OBJECTS)) ]]
|
|
|
|
[[ $(list_HEADs repdata | wc -l) -lt $((1 + 14 * NUM_OBJECTS)) ]]
|
|
|
|
[[ $(list_HEADs ecdata | wc -l) -lt $((1 + 14 * NUM_OBJECTS)) ]]
|
|
|
|
[[ $(list_HEADs rbdnonzero | wc -l) -lt $((NUM_META_RBDS + 5 * NUM_OBJECTS)) ]]
|
|
|
|
[[ $(list_HEADs clonesonly | wc -l) -eq $((NUM_META_CLONESONLY + 6 * NUM_OBJECTS)) ]]
|
|
|
|
|
|
|
|
[[ $(get_num_clones rbd) -eq $NUM_OBJECTS ]]
|
|
|
|
[[ $(get_num_clones repdata) -eq $((2 * NUM_OBJECTS)) ]]
|
|
|
|
[[ $(get_num_clones ecdata) -eq $((2 * NUM_OBJECTS)) ]]
|
|
|
|
[[ $(get_num_clones rbdnonzero) -eq $NUM_OBJECTS ]]
|
|
|
|
[[ $(get_num_clones clonesonly) -eq 0 ]]
|
2017-02-15 17:06:14 +00:00
|
|
|
|
|
|
|
echo OK
|