Whamcloud - gitweb
- merge 0.7rc1 from b_devel to HEAD (20030612 merge point)
[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}
10 MDSSIZE=${MDSSIZE:-50000}
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
19 FSTYPE=${FSTYPE:-ext3}
20
21 NETTYPE=${NETTYPE:-tcp}
22
23 # NOTE - You can't have different MDS/OST nodes and also have clients on the
24 #        MDS/OST nodes without using --endlevel and --startlevel during lconf.
25 #        You can put both MDS/OST on one node and client can be there too.
26 #        CLIENTS is a space-separated list of client nodes.
27 #
28 #        The rule is that both the MDS and the OST must be set up before any
29 #        of the clients can be started, so plan accordingly.
30
31 # Three separate systems
32 MDSNODE=${MDSNODE:-uml1}
33 OSTNODES=${OSTNODES:-"uml2 uml2"}
34 CLIENTS=${CLIENTS:-"uml3"}
35
36 # Single system with additional clients
37 #MDSNODE=uml1
38 #OSTNODES="uml1 uml1"
39 #CLIENTS="$MDSNODE client"
40
41 # Two systems with client on MDS, and additional clients (set up OST first)
42 #MDSNODE=uml1
43 #OSTNODES="uml2 uml2"
44 #CLIENTS="$MDSNODE client"
45
46 # Two systems with client on OST, and additional clients (set up MDS first)
47 #MDSNODE=uml1
48 #OSTNODES="uml2 uml2"
49 #CLIENTS="$OSTNODES client"
50
51 rm -f $config
52
53 h2tcp () {
54         case $1 in
55         client) echo '\*' ;;
56         *) echo $1 ;;
57         esac
58 }
59
60 h2elan () {
61         case $1 in
62         client) echo '\*' ;;
63         *) echo $1 | sed "s/[^0-9]*//" ;;
64         esac
65 }
66
67 # create nodes
68 echo -n "adding NET for:"
69 for NODE in `echo $MDSNODE $OSTNODES $CLIENTS | tr -s " " "\n" | sort -u`; do
70         echo -n " $NODE"
71         ${LMC} -m $config --add net --node $NODE --nid `h2$NETTYPE $NODE` --nettype $NETTYPE || exit 1
72 done
73
74 # configure mds server
75 echo; echo "adding MDS on: $MDSNODE"
76 ${LMC} -m $config --add mds --format --node $MDSNODE --mds mds1 --fstype $FSTYPE --dev $MDSDEV --size $MDSSIZE ||exit 10
77
78 # configure ost
79 ${LMC} -m $config --add lov --lov lov1 --mds mds1 --stripe_sz 65536 --stripe_cnt $STRIPECNT --stripe_pattern 0 || exit 20
80 COUNT=1
81 echo -n "adding OST on:"
82 for NODE in $OSTNODES; do
83         eval OSTDEV=\$OSTDEV$COUNT
84         echo -n " $NODE"
85         OSTDEV=${OSTDEV:-$OSTDEVBASE$COUNT}
86         ${LMC} -m $config --add ost --node $NODE --lov lov1 --fstype $FSTYPE --dev $OSTDEV --size $OSTSIZE || exit 21
87         COUNT=`expr $COUNT + 1`
88 done
89
90 # create client config(s)
91 echo; echo -n "adding CLIENT on:"
92 for NODE in $CLIENTS; do
93         echo -n " $NODE"
94         ${LMC} -m $config --add mtpt --node $NODE --path /mnt/lustre --mds mds1 --lov lov1 || exit 30
95 done
96 echo