#!/bin/bash
#
# quick and dirty reconstruct file from shards
# takes brick path and file name as arguments
# Copyright May 20th 2016 A. Neil
#
brick=$1
filen=$2
file=`find $brick -name $filen`
inode=`ls -i $file | cut -d' ' -f1`
pushd $brick/.glusterfs
gfid=`find . -inum $inode | cut -d'/' -f4`
popd
nshard=`ls -1 $brick/.shard/${gfid}.* | wc -l`
cp $file ./${filen}.restored
for i in `seq 1 $nshard`; do cat $brick/.shard/${gfid}.$i >> ./${filen}.restored; done
Il 20 mag 2016 20:14, "Alastair Neil" <ajneil.tech@xxxxxxxxx> ha scritto:
>
> I think you are confused about what sharding does. In a sharded replica 3 volume all the shards exist on all the replicas so there is no distribution. Might you be getting confused with erasure coding? The upshot of sharding is that if you have a failure, instead of healing multiple gigabyte vm files for example, you only heal the shards that have changed. This generally shortens the heal time dramatically.I know what sharding is.
it split each file in multiple, smaller, chunksBut if all is gonna bad, how can i reconstruct a file from each shard without gluster? It would be a pain.
Let's assume tens of terabytes of shards to be manually reconstructed ...Anyway how is possible to keep VM up and running when healing is happening on a shard? That part of disk image is not accessible and thus the VM could have some issue on a filesystem.
_______________________________________________ Gluster-users mailing list Gluster-users@xxxxxxxxxxx http://www.gluster.org/mailman/listinfo/gluster-users