glusterfs

Форк
0
/
multiplex.t 
78 строк · 2.3 Кб
1
#!/bin/bash
2

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

7
function count_up_bricks {
8
        $CLI --xml volume status $V0 | grep '<status>1' | wc -l
9
}
10

11
function count_brick_processes {
12
	pgrep glusterfsd | wc -l
13
}
14

15
function count_brick_pids {
16
        $CLI --xml volume status $V0 | sed -n '/.*<pid>\([^<]*\).*/s//\1/p' \
17
                                     | grep -v "N/A" | sort | uniq | wc -l
18
}
19

20
cleanup
21

22
TEST glusterd
23
TEST $CLI volume set all cluster.brick-multiplex on
24

25
TEST $CLI volume create $V0 $H0:$B0/brick{0,1}
26
TEST $CLI volume set $V0 features.trash enable
27

28
TEST $CLI volume start $V0
29
# Without multiplexing, there would be two.
30
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
31
EXPECT 1 count_brick_processes
32

33
TEST $CLI volume stop $V0
34
#Testing the volume set command introduced for protocol/server
35
TEST $CLI volume set $V0 transport.listen-backlog 1024
36
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 0 count_brick_processes
37
TEST $CLI volume start $V0
38
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
39
EXPECT 1 count_brick_processes
40

41
TEST kill_brick $V0 $H0 $B0/brick1
42
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_up_bricks
43
# Make sure the whole process didn't go away.
44
EXPECT 1 count_brick_processes
45

46
TEST $CLI volume start $V0 force
47
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
48
EXPECT 1 count_brick_processes
49

50
# Killing the first brick is a bit more of a challenge due to socket-path
51
# issues.
52
TEST kill_brick $V0 $H0 $B0/brick0
53
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_up_bricks
54
EXPECT 1 count_brick_processes
55
TEST $CLI volume start $V0 force
56
EXPECT_WITHIN $PROCESS_UP_TIMEOUT 2 count_up_bricks
57
EXPECT 1 count_brick_processes
58

59
# Make sure that the two bricks show the same PID.
60
EXPECT 1 count_brick_pids
61

62
# Do a quick test to make sure that the bricks are acting as separate bricks
63
# even though they're in the same process.
64
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0
65
for i in $(seq 10 99); do
66
        echo hello > $M0/file$i
67
done
68
nbrick0=$(ls $B0/brick0/file?? | wc -l)
69
nbrick1=$(ls $B0/brick1/file?? | wc -l)
70
TEST [ $((nbrick0 + nbrick1)) -eq 90 ]
71
TEST [ $((nbrick0 * nbrick1)) -ne 0 ]
72

73
pkill gluster
74
TEST glusterd
75
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_brick_pids
76
EXPECT_WITHIN $PROCESS_DOWN_TIMEOUT 1 count_brick_processes
77

78
cleanup;

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

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

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

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