Implementation of client_t The feature page for client_t is at http://www.gluster.org/community/documentation/index.php/Planning34/client_t In addition to adding libglusterfs/client_t.[ch] it also extracts/moves the locktable functionality from xlators/protocol/server to libglusterfs, where it is used; thus it may now be shared by other xlators too. This patch is large as it is. Hooking up the state dump is left to do in phase 2 of this patch set. (N.B. this change/patch-set supercedes previous change 3689, which was corrupted during a rebase. That change will be abandoned.) BUG: 849630 Change-Id: I1433743190630a6d8119a72b81439c0c4c990340 Signed-off-by: Kaleb S. KEITHLEY <kkeithle@redhat.com> Reviewed-on: http://review.gluster.org/3957 Tested-by: Gluster Build System <jenkins@build.gluster.com> Reviewed-by: Amar Tumballi <amarts@redhat.com>
40 lines
1.1 KiB
Bash
Executable File
40 lines
1.1 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
. $(dirname $0)/../include.rc
|
|
. $(dirname $0)/../volume.rc
|
|
|
|
function get_fd_count {
|
|
local vol=$1
|
|
local host=$2
|
|
local brick=$3
|
|
local fname=$4
|
|
local gfid_str=$(gf_gfid_xattr_to_str $(gf_get_gfid_xattr $brick/$fname))
|
|
local statedump=$(generate_brick_statedump $vol $host $brick)
|
|
local count=$(grep "gfid=$gfid_str" $statedump -A2 | grep fd-count | cut -f2 -d'=' | tail -1)
|
|
rm -f $statedump
|
|
echo $count
|
|
}
|
|
cleanup;
|
|
|
|
TEST glusterd
|
|
TEST pidof glusterd
|
|
TEST $CLI volume create $V0 $H0:$B0/${V0}0
|
|
TEST $CLI volume set $V0 performance.open-behind off
|
|
TEST $CLI volume start $V0
|
|
TEST glusterfs --volfile-id=/$V0 --volfile-server=$H0 $M0 --attribute-timeout=0 --entry-timeout=0 --direct-io-mode=enable
|
|
TEST glusterfs --volfile-id=/$V0 --volfile-server=$H0 $M1 --attribute-timeout=0 --entry-timeout=0 --direct-io-mode=enable
|
|
|
|
TEST touch $M0/a
|
|
|
|
exec 4>"$M0/a"
|
|
exec 5>"$M1/a"
|
|
EXPECT "2" get_fd_count $V0 $H0 $B0/${V0}0 a
|
|
|
|
exec 4>&-
|
|
EXPECT "1" get_fd_count $V0 $H0 $B0/${V0}0 a
|
|
|
|
exec 5>&-
|
|
EXPECT "0" get_fd_count $V0 $H0 $B0/${V0}0 a
|
|
|
|
cleanup
|