glusterfs

Форк
0
/
configure-lru-limit.t 
52 строки · 1.7 Кб
1
#!/bin/bash
2

3
. $(dirname $0)/../../include.rc
4
. $(dirname $0)/../../volume.rc
5
cleanup
6

7
TEST glusterd
8
TEST pidof glusterd
9
TEST $CLI volume create $V0 replica 3 $H0:$B0/${V0}{0,1,2}
10
TEST $CLI volume set $V0 features.shard on
11
TEST $CLI volume set $V0 features.shard-block-size 4MB
12
TEST $CLI volume set $V0 features.shard-lru-limit 25
13
TEST $CLI volume start $V0
14
EXPECT 'Started' volinfo_field $V0 'Status';
15
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}0
16
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}1
17
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}2
18

19
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0
20

21
# Perform a write that would cause 25 shards to be created, 24 of them under .shard
22
TEST dd if=/dev/zero of=$M0/foo bs=1M count=100
23

24
statedump=$(generate_mount_statedump $V0)
25
sleep 1
26
EXPECT "25" echo $(grep "lru-max-limit" $statedump | cut -f2 -d'=' | tail -1)
27

28
# Base shard is never added to this list. So all other shards should make up for 24 inodes in lru list
29
EXPECT "24" echo $(grep "inode-count" $statedump | cut -f2 -d'=' | tail -1)
30

31
rm -f $statedump
32

33
# Test to ensure there's no "reconfiguration" of the value once set.
34
TEST $CLI volume set $V0 features.shard-lru-limit 30
35
statedump=$(generate_mount_statedump $V0)
36
sleep 1
37
EXPECT "25" echo $(grep "lru-max-limit" $statedump | cut -f2 -d'=' | tail -1)
38
rm -f $statedump
39

40
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
41

42
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0
43
statedump=$(generate_mount_statedump $V0)
44
sleep 1
45
EXPECT "30" echo $(grep "lru-max-limit" $statedump | cut -f2 -d'=' | tail -1)
46
rm -f $statedump
47

48
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
49
TEST $CLI volume stop $V0
50
TEST $CLI volume delete $V0
51

52
cleanup
53

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.