replica_changeWithArbitrator.sim 6.2 KB
Newer Older
H
Hui Li 已提交
1 2 3 4
system sh/stop_dnodes.sh
system sh/deploy.sh -n dnode1 -i 1
system sh/deploy.sh -n dnode2 -i 2
system sh/deploy.sh -n dnode3 -i 3
H
Hui Li 已提交
5
system sh/deploy.sh -n dnode4 -i 4
H
Hui Li 已提交
6

H
Hui Li 已提交
7 8 9
system sh/cfg.sh -n dnode1 -c numOfMnodes -v 1
system sh/cfg.sh -n dnode2 -c numOfMnodes -v 1
system sh/cfg.sh -n dnode3 -c numOfMnodes -v 1
H
Hui Li 已提交
10
system sh/cfg.sh -n dnode4 -c numOfMnodes -v 1
H
Hui Li 已提交
11

H
Hui Li 已提交
12 13 14 15
system sh/cfg.sh -n dnode1 -c walLevel -v 2
system sh/cfg.sh -n dnode2 -c walLevel -v 2
system sh/cfg.sh -n dnode3 -c walLevel -v 2
system sh/cfg.sh -n dnode4 -c walLevel -v 2
H
Hui Li 已提交
16 17 18 19

system sh/cfg.sh -n dnode1 -c balanceInterval -v 10
system sh/cfg.sh -n dnode2 -c balanceInterval -v 10
system sh/cfg.sh -n dnode3 -c balanceInterval -v 10
H
Hui Li 已提交
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
system sh/cfg.sh -n dnode4 -c balanceInterval -v 10

system sh/cfg.sh -n dnode1 -c numOfTotalVnodes -v 8
system sh/cfg.sh -n dnode2 -c numOfTotalVnodes -v 8
system sh/cfg.sh -n dnode3 -c numOfTotalVnodes -v 8
system sh/cfg.sh -n dnode4 -c numOfTotalVnodes -v 8

system sh/cfg.sh -n dnode1 -c mnodeEqualVnodeNum -v 4
#system sh/cfg.sh -n dnode2 -c mnodeEqualVnodeNum -v 4
#system sh/cfg.sh -n dnode3 -c mnodeEqualVnodeNum -v 4
#system sh/cfg.sh -n dnode4 -c mnodeEqualVnodeNum -v 4

system sh/cfg.sh -n dnode1 -c alternativeRole -v 0
system sh/cfg.sh -n dnode2 -c alternativeRole -v 0
system sh/cfg.sh -n dnode3 -c alternativeRole -v 0
system sh/cfg.sh -n dnode4 -c alternativeRole -v 0

system sh/cfg.sh -n dnode1 -c maxtablesPerVnode -v 4
system sh/cfg.sh -n dnode2 -c maxtablesPerVnode -v 4
system sh/cfg.sh -n dnode3 -c maxtablesPerVnode -v 4
system sh/cfg.sh -n dnode4 -c maxtablesPerVnode -v 4
H
Hui Li 已提交
41 42 43 44

system sh/cfg.sh -n dnode1 -c arbitrator -v $arbitrator
system sh/cfg.sh -n dnode2 -c arbitrator -v $arbitrator
system sh/cfg.sh -n dnode3 -c arbitrator -v $arbitrator
H
Hui Li 已提交
45 46 47 48 49 50 51 52 53 54 55
system sh/cfg.sh -n dnode4 -c arbitrator -v $arbitrator

system sh/cfg.sh -n dnode1 -c offlineThreshold -v 8
system sh/cfg.sh -n dnode2 -c offlineThreshold -v 8
system sh/cfg.sh -n dnode3 -c offlineThreshold -v 8
system sh/cfg.sh -n dnode4 -c offlineThreshold -v 8

system sh/cfg.sh -n dnode1 -c statusInterval -v 3
system sh/cfg.sh -n dnode2 -c statusInterval -v 3
system sh/cfg.sh -n dnode3 -c statusInterval -v 3
system sh/cfg.sh -n dnode4 -c statusInterval -v 3
H
Hui Li 已提交
56 57 58 59

print ============== step0: start tarbitrator
system sh/exec_tarbitrator.sh -s start

H
Hui Li 已提交
60
print ============== step1: replica is 1, and start 1 dnode, then create tables and insert data
S
Shengliang Guan 已提交
61
system sh/exec.sh -n dnode1 -s start
H
Hui Li 已提交
62 63 64
sleep 3000
sql connect

H
Hui Li 已提交
65 66 67 68
$totalTableNum = 12

$db = db
sql create database $db replica 1 maxTables  $totalTableNum
H
Hui Li 已提交
69 70 71
sql use $db

# create table , insert data
H
Hui Li 已提交
72
$stb = stb
H
Hui Li 已提交
73 74
sql create table $stb (ts timestamp, c1 int) tags(t1 int)
$rowNum = 10
H
Hui Li 已提交
75 76
$tblNum = $totalTableNum
$totalRows = $rowNum * $tblNum
H
Hui Li 已提交
77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94

$ts0 = 1420041600000
$ts = $ts0
$delta = 1

$i = 0
while $i < $tblNum
  $tb = tb . $i
  sql create table $tb using $stb tags( $i )
 
  $x = 0
  while $x < $rowNum
    $xs = $x * $delta
    $ts = $ts0 + $xs
    sql insert into $tb values ( $ts , $x ) 
    $x = $x + 1
  endw 
  $i = $i + 1
H
Hui Li 已提交
95
  print       $tb inserted rows: $x
H
Hui Li 已提交
96 97
endw 

H
Hui Li 已提交
98 99 100 101 102 103
sql select count(*) from $stb
print data00 $data00
if $data00 != $totalRows then
	return -1
endi

H
Hui Li 已提交
104
print ============== step2: add 1 new dnode, expect balanced
S
Shengliang Guan 已提交
105
system sh/exec.sh -n dnode2 -s start
H
Hui Li 已提交
106
sql create dnode $hostname2
H
Hui Li 已提交
107
sleep 3000
H
Hui Li 已提交
108 109

# expect after balanced, 2 vondes in dnode1, 1 vonde in dnode2
H
Hui Li 已提交
110
$cnt = 0
H
Hui Li 已提交
111
wait_dnode2_ready:
H
Hui Li 已提交
112 113 114 115
$cnt = $cnt + 1
if $cnt == 20 then
  return -1
endi
H
Hui Li 已提交
116
sql show dnodes
H
Hui Li 已提交
117 118 119 120 121 122 123 124 125 126 127 128 129
if $rows != 2 then
  sleep 2000
  goto wait_dnode2_ready
endi
print $data0_1  $data1_1  $data2_1  $data3_1  $data4_1
print $data0_2  $data1_2  $data2_2  $data3_2  $data4_2
print $data0_3  $data1_3  $data2_3  $data3_3  $data4_3
$dnode1Status = $data4_1  
$dnode2Status = $data4_2

if $dnode1Status != ready then
  sleep 2000
  goto wait_dnode2_ready
H
Hui Li 已提交
130
endi
H
Hui Li 已提交
131 132 133
if $dnode2Status != ready then
  sleep 2000
  goto wait_dnode2_ready
H
Hui Li 已提交
134 135
endi

H
Hui Li 已提交
136
print ============== step3: stop dnode1/dnode2, modify cfg numOfMnodes to 2, and restart dnode1/dnode2
S
Shengliang Guan 已提交
137
system sh/exec.sh -n dnode1 -s stop
H
Hui Li 已提交
138 139
system sh/exec.sh -n dnode2 -s stop
sleep 3000
H
Hui Li 已提交
140

H
Hui Li 已提交
141 142 143 144 145 146 147 148 149 150 151 152 153 154 155
system sh/cfg.sh -n dnode1 -c numOfMnodes -v 2
system sh/cfg.sh -n dnode2 -c numOfMnodes -v 2

system sh/cfg.sh -n dnode1 -c mnodeEqualVnodeNum -v 4
system sh/cfg.sh -n dnode2 -c mnodeEqualVnodeNum -v 4

system sh/cfg.sh -n dnode1 -c alternativeRole -v 1
system sh/cfg.sh -n dnode2 -c alternativeRole -v 0

system sh/exec.sh -n dnode1 -s start
system sh/exec.sh -n dnode2 -s start
sleep 5000


print ============= step4: wait dnode ready
H
Hui Li 已提交
156
$cnt = 0
H
Hui Li 已提交
157
wait_dnode_ready:
H
Hui Li 已提交
158 159 160 161
$cnt = $cnt + 1
if $cnt == 10 then
  return -1
endi
H
Hui Li 已提交
162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197
sql show dnodes
if $rows != 2 then
  sleep 2000
  goto wait_dnode_ready
endi
print $data0_1  $data1_1  $data2_1  $data3_1  $data4_1
print $data0_2  $data1_2  $data2_2  $data3_2  $data4_2
#print $data0_3  $data1_3  $data2_3  $data3_3  $data4_3
#print $data0_4  $data1_4  $data2_4  $data3_4  $data4_4
#print $data0_5  $data1_5  $data2_5  $data3_5  $data4_5
#print $data0_6  $data1_6  $data2_6  $data3_6  $data4_6
$dnode1Status = $data4_1  
$dnode2Status = $data4_2
#$dnode3Status = $data4_3  
#$dnode4Status = $data4_4 
#$dnode5Status = $data4_5

if $dnode1Status != ready then
  sleep 2000
  goto wait_dnode_ready
endi
if $dnode2Status != ready then
  sleep 2000
  goto wait_dnode_ready
endi

sql select count(*) from $stb
print data00 $data00
if $data00 != $totalRows then
	return -1
endi

print ============== step5: stop dnode1
system sh/exec.sh -n dnode1 -s stop
sleep 3000

H
Hui Li 已提交
198
$cnt = 0
H
Hui Li 已提交
199
wait_dnode2_master:
H
Hui Li 已提交
200 201 202 203
$cnt = $cnt + 1
if $cnt == 10 then
  return -1
endi
H
Hui Li 已提交
204
sql show mnodes
H
Hui Li 已提交
205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228
if $rows != 2 then
  sleep 2000
  goto wait_dnode2_master
endi
print $data0_1  $data1_1  $data2_1  $data3_1  $data4_1
print $data0_2  $data1_2  $data2_2  $data3_2  $data4_2
#print $data0_3  $data1_3  $data2_3  $data3_3  $data4_3
#print $data0_4  $data1_4  $data2_4  $data3_4  $data4_4
#print $data0_5  $data1_5  $data2_5  $data3_5  $data4_5
#print $data0_6  $data1_6  $data2_6  $data3_6  $data4_6
$dnode1Status = $data4_1  
$dnode2Status = $data4_2
#$dnode3Status = $data4_3  
#$dnode4Status = $data4_4 
#$dnode5Status = $data4_5

if $data2_1 != offline then
  sleep 2000
  goto wait_dnode2_master
endi
if $data2_2 != master then
  sleep 2000
  goto wait_dnode2_master
endi
H
Hui Li 已提交
229

H
Hui Li 已提交
230 231 232 233
sql select count(*) from $stb
print data00 $data00
if $data00 != $totalRows then
	return -1
H
Hui Li 已提交
234
endi
H
Hui Li 已提交
235 236