summaryrefslogtreecommitdiffstats
path: root/scripts/maintain/gluster
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/maintain/gluster')
-rw-r--r--scripts/maintain/gluster/bricks_move_heketi.sh39
-rw-r--r--scripts/maintain/gluster/bricks_populate.sh11
-rw-r--r--scripts/maintain/gluster/heal-walk.sh35
3 files changed, 85 insertions, 0 deletions
diff --git a/scripts/maintain/gluster/bricks_move_heketi.sh b/scripts/maintain/gluster/bricks_move_heketi.sh
new file mode 100644
index 0000000..36b8602
--- /dev/null
+++ b/scripts/maintain/gluster/bricks_move_heketi.sh
@@ -0,0 +1,39 @@
+HOST="192.168.12.1"
+NEW_BASE="/mnt/ands/glusterfs/vg_ce3a7c1bb6da5c98ce4bb3e76aeacb8b"
+GLUSTER_BIN="gluster"
+DRYRUN=1 # set to 0 to actually run
+GLUSTER_UID=107 # adjust if your gluster user has a different uid/gid
+
+# get all volumes like vol_<uid>
+VOLS=$($GLUSTER_BIN volume list | grep '^vol_')
+
+for VOL in $VOLS; do
+ # find bricks on this host
+ # lines look like: "Brick2: 192.168.12.1:/var/lib/heketi/.../brick"
+ mapfile -t OLDBRICKS < <($GLUSTER_BIN volume info "$VOL" \
+ | grep "$HOST:" \
+ | awk '{print $2}')
+
+ # skip volumes that don't have a brick on this host
+ if [ ${#OLDBRICKS[@]} -eq 0 ]; then
+ continue
+ fi
+
+ for OLD in "${OLDBRICKS[@]}"; do
+ BRICKID=$(echo "$OLD" | sed -n 's#.*/\(brick_[^/]*\)/brick#\1#p')
+ if [ -z "$BRICKID" ]; then
+ echo "WARN: could not extract brick ID from $OLD"
+ continue
+ fi
+
+ NEW="$HOST:$NEW_BASE/$BRICKID"
+
+ echo "=== volume: $VOL ==="
+ echo "old brick: $OLD"
+ echo "new brick: $NEW"
+
+
+ $GLUSTER_BIN volume replace-brick "$VOL" "$OLD" "$NEW" commit force
+
+ done
+done
diff --git a/scripts/maintain/gluster/bricks_populate.sh b/scripts/maintain/gluster/bricks_populate.sh
new file mode 100644
index 0000000..15790a1
--- /dev/null
+++ b/scripts/maintain/gluster/bricks_populate.sh
@@ -0,0 +1,11 @@
+for brick in brick-*; do
+ [ -d $brick/.glusterfs ] && continue
+ name=${brick#brick-}
+
+ echo "$name - $brick"
+
+ setfattr -n trusted.gfid -v 0sAAAAAAAAAAAAAAAAAAAAAQ== /mnt/ands/glusterfs/$brick
+ setfattr -n trusted.glusterfs.volume-id -v 0x$(gluster volume info $name | grep 'Volume ID' | awk '{print $3}' | tr -d '-') /mnt/ands/glusterfs/$brick
+ mkdir -p /mnt/ands/glusterfs/$brick/.glusterfs/{indices,exports,xattrop,locks}
+
+done
diff --git a/scripts/maintain/gluster/heal-walk.sh b/scripts/maintain/gluster/heal-walk.sh
new file mode 100644
index 0000000..4c8d134
--- /dev/null
+++ b/scripts/maintain/gluster/heal-walk.sh
@@ -0,0 +1,35 @@
+#! /bin/bash
+
+
+#find /mnt/provision/kaas/adei -type f -print0 | xargs -0 -I{} -n 1 sh -c ' dd if="$1" of=/dev/null bs=1M status=none || true; sleep .5' _ "{}"
+
+#find /mnt/ands/glusterfs/brick-provision/kaas/bora -type f -size 0 -print0 | \
+#while IFS= read -r -d '' f; do
+# echo "Remvoing $f"
+# setfattr -x trusted.glusterfs.mdata "$f" 2>/dev/null || true
+# for a in $(getfattr -d -m trusted.afr -e hex "$f" 2>/dev/null | awk -F= '/trusted\.afr/{print $1}'); do
+# setfattr -x "$a" "$f" 2>/dev/null || true
+# done
+#done
+
+#find /mnt/datastore/services/gogs -type f -print0 | xargs -0 -n200 -P16 rm -
+#find /mnt/datastore/services/gogs -depth -type d -empty -delete
+#find /mnt/datastore/services/gogs/repositories -maxdepth 1 -mindepth 1 -type d -print0 | xargs -0 -I{} -n1 -P200 sh -c 'rm -rf "$1"' _ "{}"
+
+
+echo 3 | sudo tee /proc/sys/vm/drop_caches
+find /mnt/wave/ -type f -print0 | xargs -0 -I{} -n 1 -P 8 sh -c '
+ f="$1"
+ dd if="$f" of=/dev/null bs=1M status=none || true;
+ sz=$(stat -c%s "$f" 2>/dev/null || echo 0)
+ echo "$f $sz"
+ if [ "$sz" -eq 0 ]; then
+ # give gluster a breath and try again, like you do manually
+ sleep 0.5
+ dd if="$f" of=/dev/null bs=1M status=none 2>/dev/null || true
+# sz=$(stat -c%s "$f" 2>/dev/null || echo 0)
+ fi
+ ' _ "{}"
+
+
+#find /mnt/wave/ -type f -print0 | xargs -0 -I{} -n 1 -P 8 sh -c 'echo $1; dd if="$1" of=/dev/null bs=1M status=none || true; sleep .5' _ {}