Whamcloud - gitweb
landing b_cmobd_merge on HEAD
[fs/lustre-release.git] / lustre / tests / uml.sh
1 #!/bin/bash
2
3 export PATH=`dirname $0`/../utils:$PATH
4
5 config=${1:-uml.xml}
6 LMC=${LMC:-lmc}
7 TMP=${TMP:-/tmp}
8
9 MDSDEV=${MDSDEV:-$TMP/mds1-`hostname`}
10 MDSSIZE=${MDSSIZE:-100000}
11
12 OSTDEVBASE=$TMP/ost
13 #OSTDEV1=${OSTDEV1:-${OSTDEVBASE}1}
14 #OSTDEV2=${OSTDEV2:-${OSTDEVBASE}2}
15 #etc
16 OSTSIZE=${OSTSIZE:-100000}
17 STRIPECNT=${STRIPECNT:-1}
18 STRIPE_BYTES=${STRIPE_BYTES:-1048576}
19 OSDTYPE=${OSDTYPE:-obdfilter}
20 OSTFAILOVER=${OSTFAILOVER:-}
21
22 FSTYPE=${FSTYPE:-ext3}
23
24 NETTYPE=${NETTYPE:-tcp}
25 NIDTYPE=${NIDTYPE:-$NETTYPE}
26
27 # NOTE - You can't have different MDS/OST nodes and also have clients on the
28 #        MDS/OST nodes without using --endlevel and --startlevel during lconf.
29 #        You can put both MDS/OST on one node and client can be there too.
30 #        CLIENTS is a space-separated list of client nodes.
31 #
32 #        The rule is that both the MDS and the OST must be set up before any
33 #        of the clients can be started, so plan accordingly.
34
35 # Three separate systems
36 MDSNODE=${MDSNODE:-uml1}
37 OSTNODES=${OSTNODES:-"uml2 uml2"}
38 CLIENTS=${CLIENTS:-"uml3"}
39
40 # Single system with additional clients
41 #MDSNODE=uml1
42 #OSTNODES="uml1 uml1"
43 #CLIENTS="$MDSNODE client"
44
45 # Two systems with client on MDS, and additional clients (set up OST first)
46 #MDSNODE=uml1
47 #OSTNODES="uml2 uml2"
48 #CLIENTS="$MDSNODE client"
49
50 # Two systems with client on OST, and additional clients (set up MDS first)
51 #MDSNODE=uml1
52 #OSTNODES="uml2 uml2"
53 #CLIENTS="$OSTNODES client"
54
55 rm -f $config
56
57 h2localhost () {
58         echo localhost
59 }
60         
61 h2tcp () {
62         case $1 in
63         client) echo '\*' ;;
64         *) echo $1 ;;
65         esac
66 }
67
68 h2elan () {
69         case $1 in
70         client) echo '\*' ;;
71         *) echo $1 | sed "s/[^0-9]*//" ;;
72         esac
73 }
74
75 h2gm () {
76         echo `gmnalnid -n$1`
77 }
78
79 # create nodes
80 echo -n "adding NET for:"
81 for NODE in `echo $MDSNODE $OSTNODES $CLIENTS | tr -s " " "\n" | sort -u`; do
82         echo -n " $NODE"
83         ${LMC} -m $config --add net --node $NODE --nid `h2$NIDTYPE $NODE` --nettype $NETTYPE || exit 1
84 done
85
86 # configure mds server
87 echo; echo "adding MDS on: $MDSNODE"
88 ${LMC} -m $config --add mds --format --node $MDSNODE --mds mds1 --fstype $FSTYPE --dev $MDSDEV --size $MDSSIZE ||exit 10
89
90 # configure ost
91 ${LMC} -m $config --add lov --lov lov1 --mds mds1 --stripe_sz $STRIPE_BYTES --stripe_cnt $STRIPECNT --stripe_pattern 0 || exit 20
92 COUNT=1
93 echo -n "adding OST on:"
94 for NODE in $OSTNODES; do
95         eval OSTDEV=\$OSTDEV$COUNT
96         echo -n " $NODE"
97         OSTDEV=${OSTDEV:-$OSTDEVBASE$COUNT-`hostname`}
98         case "$OSDTYPE" in
99                 obdfilter)
100                         OSTARGS="--fstype $FSTYPE --dev $OSTDEV --size $OSTSIZE"
101                         ;;
102                 obdecho)
103                         OSTARGS="--osdtype=obdecho"
104                         ;;
105         esac
106         ${LMC} -m $config --add ost --node $NODE --lov lov1 $OSTARGS $OSTFAILOVER || exit 21
107         COUNT=`expr $COUNT + 1`
108 done
109
110 # create client config(s)
111 echo; echo -n "adding CLIENT on:"
112 for NODE in $CLIENTS; do
113         echo -n " $NODE"
114         ${LMC} -m $config --add mtpt --node $NODE --path /mnt/lustre --mds mds1 --lov lov1 || exit 30
115 done
116 echo