1 | #!/bin/bash |
---|
2 | IP_LIST="192.168.100.1 192.168.100.2 192.168.100.4 192.168.100.5 192.168.100.11 192.168.100.12 192.168.100.13 192.168.100.14 192.168.100.21 192.168.100.22 192.168.100.24 192.168.100.25" |
---|
3 | export LANG=en_US |
---|
4 | export LC_ALL=en_US |
---|
5 | log_start=$(date +"%y%m%d-%H%M%S_") |
---|
6 | log_file="/var/log/${log_start}diskless-benchmark.log" |
---|
7 | status_file="/var/log/${log_start}diskless-benchmark-status.log" |
---|
8 | local_zip="/var/log/${log_start}diskless.tar.gz" |
---|
9 | echo "0. Rebooting...." > $log_file |
---|
10 | echo "0. Rebooting...." |
---|
11 | /opt/drbl/sbin/dcs -h "$IP_LIST" remote-linux-txt 2>&1 > $status_file |
---|
12 | source /home/jazz/.bash_aliases |
---|
13 | up-host-a > /root/.dsh/machines.list |
---|
14 | |
---|
15 | function mydsh() |
---|
16 | { |
---|
17 | dsh -a -c "date > /var/log/$2.time.$1; /usr/bin/time -a -o /var/log/$2.time.$i $3; date >> /var/log/$2.time.$1" >> $status_file 2>&1 |
---|
18 | } |
---|
19 | |
---|
20 | echo "START diskless Benchmark ...." >> $log_file |
---|
21 | for ((i=1;i<=10;i++)); do |
---|
22 | echo "[$i] 1. Booting...." >> $log_file |
---|
23 | echo "[$i] 1. Booting...." |
---|
24 | dsh -a -c "reboot" 2>&1 >> $status_file |
---|
25 | `date >> $log_file` |
---|
26 | sleep 120 |
---|
27 | dsh -a -c "echo 3 > /proc/sys/vm/drop_caches" |
---|
28 | echo "[$i] 2. Running dd ...." >> $log_file |
---|
29 | echo "[$i] 2. Running dd ...." |
---|
30 | `date >> $log_file` |
---|
31 | mydsh "$i" "dd" "dd if=/dev/zero of=/root/E2CC.img bs=1M count=1024" |
---|
32 | `date >> $log_file` |
---|
33 | sleep 120 |
---|
34 | echo "[$i] 3. Running tar ...." >> $log_file |
---|
35 | echo "[$i] 3. Running tar ...." |
---|
36 | `date >> $log_file` |
---|
37 | mydsh "$i" "tar" "tar zcvf /root/E2CC.img.tar.gz /root/E2CC.img" |
---|
38 | `date >> $log_file` |
---|
39 | sleep 120 |
---|
40 | echo "[$i] 4. Running bonnie++ ...." >> $log_file |
---|
41 | echo "[$i] 4. Running bonnie++ ...." |
---|
42 | `date >> $log_file` |
---|
43 | mydsh "$i" "bonnie++" "bonnie++ -u root -d /root -s 2000" |
---|
44 | `date >> $log_file` |
---|
45 | sleep 120 |
---|
46 | echo "[$i] *. Download Kernel ...." >> $log_file |
---|
47 | echo "[$i] *. Download Kernel ...." |
---|
48 | `date >> $log_file` |
---|
49 | mydsh "$i" "download-kernel" "wget -O /tmp/linux-2.6.30.tar.bz2 http://www.kernel.org/pub/linux/kernel/v2.6/linux-2.6.30.tar.bz2 -o /tmp/linux-2.6.30.log" |
---|
50 | `date >> $log_file` |
---|
51 | echo "[$i] *. Extract Kernel ...." >> $log_file |
---|
52 | echo "[$i] *. Extract Kernel ...." |
---|
53 | `date >> $log_file` |
---|
54 | mydsh "$i" "extrac-kernel" "tar jxvf /tmp/linux-2.6.30.tar.bz2 -C /tmp; rm -f /tmp/linux-2.6.30.tar.bz2" |
---|
55 | `date >> $log_file` |
---|
56 | echo "[$i] *. Configure Kernel ...." >> $log_file |
---|
57 | echo "[$i] *. Configure Kernel ...." |
---|
58 | `date >> $log_file` |
---|
59 | mydsh "$i" "make-allnoconf" "make -C /tmp/linux-2.6.30 allnoconfig" |
---|
60 | `date >> $log_file` |
---|
61 | echo "[$i] 5. Running make -j 1 ...." >> $log_file |
---|
62 | echo "[$i] 5. Running make -j 1 ...." |
---|
63 | `date >> $log_file` |
---|
64 | mydsh "$i-1" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
65 | mydsh "$i-1" "make-j1" "make -j 1 -C /tmp/linux-2.6.30" |
---|
66 | mydsh "$i-2" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
67 | mydsh "$i-2" "make-j1" "make -j 1 -C /tmp/linux-2.6.30" |
---|
68 | `date >> $log_file` |
---|
69 | sleep 120 |
---|
70 | echo "[$i] 6. Running make -j 2 ...." >> $log_file |
---|
71 | echo "[$i] 6. Running make -j 2 ...." |
---|
72 | `date >> $log_file` |
---|
73 | mydsh "$i-1" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
74 | mydsh "$i-1" "make-j2" "make -j 2 -C /tmp/linux-2.6.30" |
---|
75 | mydsh "$i-2" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
76 | mydsh "$i-2" "make-j2" "make -j 2 -C /tmp/linux-2.6.30" |
---|
77 | mydsh "$i-3" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
78 | mydsh "$i-3" "make-j2" "make -j 2 -C /tmp/linux-2.6.30" |
---|
79 | `date >> $log_file` |
---|
80 | sleep 120 |
---|
81 | echo "[$i] 7. Running make -j 3 ...." >> $log_file |
---|
82 | echo "[$i] 7. Running make -j 3 ...." |
---|
83 | `date >> $log_file` |
---|
84 | mydsh "$i-1" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
85 | mydsh "$i-1" "make-j3" "make -j 3 -C /tmp/linux-2.6.30" |
---|
86 | mydsh "$i-2" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
87 | mydsh "$i-2" "make-j3" "make -j 3 -C /tmp/linux-2.6.30" |
---|
88 | mydsh "$i-3" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
89 | mydsh "$i-3" "make-j3" "make -j 3 -C /tmp/linux-2.6.30" |
---|
90 | `date >> $log_file` |
---|
91 | sleep 120 |
---|
92 | echo "[$i] 8. Running make -j 4 ...." >> $log_file |
---|
93 | echo "[$i] 8. Running make -j 4 ...." |
---|
94 | `date >> $log_file` |
---|
95 | mydsh "$i-1" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
96 | mydsh "$i-1" "make-j4" "make -j 4 -C /tmp/linux-2.6.30" |
---|
97 | mydsh "$i-2" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
98 | mydsh "$i-2" "make-j4" "make -j 4 -C /tmp/linux-2.6.30" |
---|
99 | mydsh "$i-3" "make-clean" "make clean -C /tmp/linux-2.6.30" |
---|
100 | mydsh "$i-3" "make-j4" "make -j 4 -C /tmp/linux-2.6.30" |
---|
101 | `date >> $log_file` |
---|
102 | done |
---|
103 | mydsh "F" "collect" "tar zcvf $local_zip /var/log/*.time.*" |
---|