summaryrefslogtreecommitdiffstats
path: root/tests/basic/cache.t
blob: 92251732f4a9f67ed6d749f81fe9fcc312172d22 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#!/bin/bash
#

FILE=/var/log/glusterfs/samples/glusterfs_patchy.samp
rm $FILE

. $(dirname $0)/../include.rc
. $(dirname $0)/../volume.rc

function print_cnt() {
  local FOP_TYPE=$1
  local FOP_CNT=$(grep ,${FOP_TYPE} $FILE | wc -l)
  echo $FOP_CNT
}

function print_avg() {
  local FOP_TYPE=$1
  local FILE=/var/log/glusterfs/samples/glusterfs_patchy.samp
  local FOP_AVG=$(grep -oE "${FOP_TYPE},[0-9]+\." ${FILE} | grep -oE '[0-9]+' | awk 'NR == 1 { sum = 0 } { sum += $1; } END {printf "%d", sum/NR}')
  echo $FOP_AVG
}

cleanup;
TEST glusterd
TEST pidof glusterd
TEST $CLI volume create $V0 replica 3 $H0:$B0/${V0}{0,1,2}
TEST $CLI volume set $V0 nfs.disable off
TEST $CLI volume set $V0 diagnostics.latency-measurement on
TEST $CLI volume set $V0 diagnostics.count-fop-hits on
TEST $CLI volume set $V0 diagnostics.fop-sample-buf-size 65535
TEST $CLI volume set $V0 diagnostics.fop-sample-interval 1
TEST $CLI volume set $V0 diagnostics.stats-dump-interval 1
TEST $CLI volume start $V0
TEST glusterfs --volfile-id=/$V0 --volfile-server=$H0 $M0 --attribute-timeout=0 --entry-timeout=0

for i in {1..100}
do
        df $M0 &> /dev/null
done

sleep 6

# Get average
STATFS_CNT0=$(print_cnt STATFS)
TEST [ "$STATFS_CNT0" -gt "0" ]
STATFS_AVG0=$(print_avg STATFS)
# Make it easier to compute averages
rm $FILE

TEST $CLI volume set $V0 performance.nfs.io-cache on
TEST $CLI volume set $V0 performance.statfs-cache on
TEST $CLI volume set $V0 performance.statfs-cache-timeout 10

for i in {1..100}
do
        df $M0 &> /dev/null
done

sleep 6

# Get average
STATFS_CNT1=$(print_cnt STATFS)
TEST [ "$STATFS_CNT1" -eq "$STATFS_CNT0" ]
STATFS_AVG1=$(print_avg STATFS)

# Verify that cached average * 10 is still faster than uncached
STATFS_AVG1x10=$(($STATFS_AVG1 * 10))
TEST [ "$STATFS_AVG0" -gt "$STATFS_AVG1x10" ]
#cleanup