2013-02-11 22:27:29 +05:30
#!/bin/bash
function get_layout()
{
2013-04-04 11:23:08 +05:30
getfattr -n trusted.glusterfs.dht -e hex $1 2>&1|grep dht |cut -d = -f2
2013-02-11 22:27:29 +05:30
}
## populates $BRICK1 and $BRICK2 with hashed/cached subvolume. These will be
## used by get_cached_brick and get_hashed_brick
function file_has_linkfile()
{
k=0
l=0
while [ $k -lt $BRICK_COUNT ]
do
stat=`stat $B0/${V0}$k/$1 2>/dev/null`
if [ $? -eq 0 ]
then
let l++
let "BRICK${l}=$k"
fi
let k++
done
return $l
}
function get_cached_brick()
{
i=1
brick=$BRICK1
while [ $i -lt 3 ]
do
test=`getfattr -n trusted.glusterfs.dht.linkto -e text $B0/${V0}$brick/$1 2>&1`
if [ $? -eq 1 ]
then
cached=$brick
i=$(( $i+3 ))
fi
brick=$BRICK1
let i++
done
return $cached
}
function get_hashed_brick()
{
j=1
brick=$BRICK1
while [ $j -lt 3 ]
do
test=`getfattr -n trusted.glusterfs.dht.linkto -e text $B0/${V0}$brick/$1 2>&1`
if [ $? -eq 0 ]
then
hashed=$brick
j=$(( $j+3 ))
fi
brick=$BRICK2
let j++
done
return $hashed
}
2013-02-25 10:02:15 +05:30
function rebalance_completed()
{
val=1
test=`gluster volume rebalance $V0 status |grep localhost|grep -v "in progress" 2>&1`
if [ $? -eq 0 ]
then
val=0
fi
echo $val
2014-03-25 09:36:45 +05:30
return $val
2013-02-25 10:02:15 +05:30
}
2014-04-21 18:59:00 +05:30
function remove_brick_completed()
{
val=1
test=`gluster volume remove-brick $V0 $H0:$B0/${V0}2 status |grep localhost|grep -v "in progress" 2>&1`
if [ $? -eq 0 ]
then
val=0
fi
echo $val
return $val
}
2014-05-21 17:47:03 +05:30
function dht_get_linkto_target()
{
local path=$1;
echo `getfattr -d -m . -e text --only-values --absolute-names --name=trusted.glusterfs.dht.linkto $path`
}
function is_dht_linkfile()
{
local path=$1
retval=0
local output=`stat --format=%a $path`
if [ $output -eq 1000 ]; then
retval=1
fi
echo $retval
return $retval
}