-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdeploy.sh
380 lines (304 loc) · 12.9 KB
/
deploy.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
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
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
#!/bin/bash
#
## Initial variables
PROJECT_ROOT_PATH=$(cd $(dirname $BASH_SOURCE); pwd)
CUSTOMER_ID=""
HOST_NAME=""
ROOT_URL=""
MONGO_URL=""
PRODUCTION_HOST_NAME=""
PRODUCTION_ROOT_URL=""
PRODUCTION_MONGO_URL=""
TEST_HOST_NAME=""
TEST_HOST_NAME=""
TEST_MONGO_URL=""
PRIVATE_KEY=""
IP_ADDRESS=""
AWS_ACCESS_KEY="AKIAJSCML3VTEAVLR5RA"
AWS_SECRET_KEY="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"
SPAWN_SERVERS=false
TEST_SETUP=false
BACKUP_PRODUCTION=false
PRODUCTION_SETUP=false
ERPNEXT_INITIAL_SETUP=false
MONGODB_INITIAL_SETUP=false
SERVER_DESTROY=false
NEXTACTION_SETUP=false
NEXTACTION_BRANCH=$(git branch | sed -n -e 's/^\* \(.*\)/\1/p')
TEST_NEXTACTION=false
PRODUCTION_NEXTACTION=false
RESTORE_TEST_ERPDATA=""
RESTORE_TEST_NEXTACTION=""
RESTORE_TEST_SERVER=false
RESTORE_PRODUCTION_ERPDATA=""
RESTORE_PRODUCTION_NEXTACTION=""
RESTORE_PRODUCTION_SERVER=false
RESTORE_ERPDATA=""
RESTORE_NEXTACTION=""
#
## Reset in case getopts has been used previously in the shell
#
OPTIND=1
while getopts "c:i:r:R:SptBDnN" opt; do
case "$opt" in
c )
CUSTOMER_ID="$OPTARG"
HOST_NAME="$OPTARG"'.openb.net'
TEST_HOST_NAME="$OPTARG"'.openb.net'
TEST_ROOT_URL='http://'"$OPTARG"'.openb.net/'
TEST_MONGO_URL='mongodb://'"$OPTARG"'.openb.net:27017/nextaction'
PRODUCTION_HOST_NAME="$OPTARG"'.nextaction.co'
PRODUCTION_ROOT_URL='http://'"$OPTARG"'.nextaction.co/'
PRODUCTION_MONGO_URL='mongodb://'"$OPTARG"'.nextaction.co:27017/nextaction'
;;
i )
PRIVATE_KEY="$OPTARG"
;;
r )
RESTORE_TEST_ERPDATA="$CUSTOMER_ID"'-erpdata-'"$OPTARG"'.tar.xz'
RESTORE_TEST_NEXTACTION="$CUSTOMER_ID"'-nextaction-'"$OPTARG"'.tar.xz'
RESTORE_TEST_SERVER=true
;;
R )
RESTORE_PRODUCTION_ERPDATA="$CUSTOMER_ID"'-erpdata-'"$OPTARG"'.tar.xz'
RESTORE_PRODUCTION_NEXTACTION="$CUSTOMER_ID"'-nextaction-'"$OPTARG"'.tar.xz'
RESTORE_PRODUCTION_SERVER=true
;;
S )
SPAWN_SERVERS=true
;;
p )
PRODUCTION_SETUP=true
;;
t )
TEST_SETUP=true
;;
B )
BACKUP_PRODUCTION=true
;;
D )
SERVER_DESTROY=true
;;
N )
PRODUCTION_NEXTACTION=true
;;
n )
TEST_NEXTACTION=true
;;
esac
done
spawn_servers() {
echo "Spawning new server: $HOST_NAME"
tugboat create $HOST_NAME
tugboat wait $HOST_NAME
sleep 10
}
production_setup() {
IP_ADDRESS="`tugboat info -n "$HOST_NAME" --attribute ip --porcelain`"
echo "Server's IP Address: $IP_ADDRESS"
ssh -o "StrictHostKeyChecking no" -i $PRIVATE_KEY root@$IP_ADDRESS /bin/bash -c "'
docker rm -f route53 route53erp nginx-proxy &> /dev/null
docker run --rm --name route53 -e AWS_ACCESS_KEY_ID="$AWS_ACCESS_KEY" -e AWS_SECRET_ACCESS_KEY="$AWS_SECRET_KEY" -e AWS_CONNECTION_REGION="ap-southeast-1" -e HOST_NAME="$HOST_NAME" -e IP_ADDRESS="$IP_ADDRESS" -e ROUTE53_UPDATE_FREQUENCY=300 hanselke/route53:v1.7.1 '/opt/route53/r53dyndns.py' -I "$IP_ADDRESS" -R "$HOST_NAME"
docker run --rm --name route53erp -e AWS_ACCESS_KEY_ID="$AWS_ACCESS_KEY" -e AWS_SECRET_ACCESS_KEY="$AWS_SECRET_KEY" -e AWS_CONNECTION_REGION="ap-southeast-1" -e HOST_NAME='erp.'"$HOST_NAME" -e IP_ADDRESS="$IP_ADDRESS" -e ROUTE53_UPDATE_FREQUENCY=300 hanselke/route53:v1.7.1 '/opt/route53/r53dyndns.py' -I "$IP_ADDRESS" -R 'erp.'"$HOST_NAME"
docker run --name nginx-proxy -d -p 80:80 -v /var/run/docker.sock:/tmp/docker.sock:ro jwilder/nginx-proxy
'"
}
test_setup() {
IP_ADDRESS="`tugboat info -n "$HOST_NAME" --attribute ip --porcelain`"
echo "Server's IP Address: $IP_ADDRESS"
ssh -o "StrictHostKeyChecking no" -i $PRIVATE_KEY root@$IP_ADDRESS /bin/bash -c "'
docker rm -f route53 route53erp nginx-proxy &> /dev/null
docker run --rm --name route53 -e AWS_ACCESS_KEY_ID="$AWS_ACCESS_KEY" -e AWS_SECRET_ACCESS_KEY="$AWS_SECRET_KEY" -e AWS_CONNECTION_REGION="ap-southeast-1" -e HOST_NAME="$HOST_NAME" -e IP_ADDRESS="$IP_ADDRESS" -e ROUTE53_UPDATE_FREQUENCY=300 hanselke/route53:v1.7.1 '/opt/route53/r53dyndns.py' -I "$IP_ADDRESS" -R "$HOST_NAME"
docker run --rm --name route53erp -e AWS_ACCESS_KEY_ID="$AWS_ACCESS_KEY" -e AWS_SECRET_ACCESS_KEY="$AWS_SECRET_KEY" -e AWS_CONNECTION_REGION="ap-southeast-1" -e HOST_NAME='erp.'"$HOST_NAME" -e IP_ADDRESS="$IP_ADDRESS" -e ROUTE53_UPDATE_FREQUENCY=300 hanselke/route53:v1.7.1 '/opt/route53/r53dyndns.py' -I "$IP_ADDRESS" -R 'erp.'"$HOST_NAME"
docker run --name nginx-proxy -d -p 80:80 -v /var/run/docker.sock:/tmp/docker.sock:ro jwilder/nginx-proxy
'"
}
erpnext_initial_setup() {
echo "Setting up ERP system"
IP_ADDRESS="`tugboat info -n "$HOST_NAME" --attribute ip --porcelain`"
ssh -o "StrictHostKeyChecking no" -i $PRIVATE_KEY root@$IP_ADDRESS /bin/bash -c "'
docker rm -f erpdata erpnext &> /dev/null
docker create -v /home/frappe/frappe-bench/sites/site1.local/ -v /var/lib/mysql --name erpdata davidgu/erpnext
docker run -d -p 3500:80 --name erpnext -e VIRTUAL_HOST='erp.'"$HOST_NAME" -e VIRTUAL_PORT="3500" --volumes-from erpdata davidgu/erpnext
'"
}
mongodb_initial_setup() {
echo "Setting up MongoDB"
IP_ADDRESS="`tugboat info -n "$HOST_NAME" --attribute ip --porcelain`"
ssh -o "StrictHostKeyChecking no" -i $PRIVATE_KEY root@$IP_ADDRESS /bin/bash -c "'
rm -rf /opt/mongo_data &> /dev/null
mkdir /opt/mongo_data &> /dev/null
docker rm -f mongo &> /dev/null
docker run -d -p 27017:27017 --name mongo -v /opt/mongo_data:/data/db mongo
'"
}
nextaction_setup() {
echo "Setting up NextAction"
IP_ADDRESS="`tugboat info -n "$HOST_NAME" --attribute ip --porcelain`"
echo $IP_ADDRESS
echo $ROOT_URL
meteor build --architecture=os.linux.x86_64 /tmp
scp -o "StrictHostKeyChecking no" -i $PRIVATE_KEY /tmp/"$NEXTACTION_BRANCH".tar.gz root@$IP_ADDRESS:/opt
ssh -o "StrictHostKeyChecking no" -i $PRIVATE_KEY root@$IP_ADDRESS /bin/bash -c "'
docker rm -f nextaction &> /dev/null
docker run --name nextaction -d -e VIRTUAL_HOST="$HOST_NAME" -e VIRTUAL_PORT="4000" -e ROOT_URL='http://'"$HOST_NAME" -e MONGO_URL='mongodb://'"$HOST_NAME"':27017/nextaction' -v /opt:/bundle -p 4000:80 meteorhacks/meteord:base
'"
}
server_destroy() {
echo "Destroying server"
IP_ADDRESS="`tugboat info -n "$HOST_NAME" --attribute ip --porcelain`"
ssh -o "StrictHostKeyChecking no" -i $PRIVATE_KEY root@$IP_ADDRESS /bin/bash -c "'
docker rm -f nextaction &> /dev/null
rm -rf /opt/mongodb &> /dev/null
docker rm -f route53 route53erp nginx-proxy
docker run -d --name route53 -e AWS_ACCESS_KEY_ID="$AWS_ACCESS_KEY" -e AWS_SECRET_ACCESS_KEY="$AWS_SECRET_KEY" -e AWS_CONNECTION_REGION="ap-southeast-1" -e HOST_NAME="$HOST_NAME" -e IP_ADDRESS="$IP_ADDRESS" -e ROUTE53_UPDATE_FREQUENCY=600 hanselke/route53:v1.7.1 '/opt/route53/r53dyndns.py' -I "8.8.8.8" -R "$HOST_NAME"
docker run -d --name route53erp -e AWS_ACCESS_KEY_ID="$AWS_ACCESS_KEY" -e AWS_SECRET_ACCESS_KEY="$AWS_SECRET_KEY" -e AWS_CONNECTION_REGION="ap-southeast-1" -e HOST_NAME='erp.'"$HOST_NAME" -e IP_ADDRESS="$IP_ADDRESS" -e ROUTE53_UPDATE_FREQUENCY=600 hanselke/route53:v1.7.1 '/opt/route53/r53dyndns.py' -I "8.8.8.8" -R 'erp.'"$HOST_NAME"
'"
sleep 10
tugboat destroy $HOST_NAME
}
backup_production() {
echo "Backing up $PRODUCTION_HOST_NAME into $TEST_HOST_NAME"
HOST_NAME=$PRODUCTION_HOST_NAME
ROOT_URL=$PRODUCTION_ROOT_URL
MONGO_URL=$PRODUCTION_MONGO_URL
IP_ADDRESS="`tugboat info -n "$HOST_NAME" --attribute ip --porcelain`"
ssh -o "StrictHostKeyChecking no" -i $PRIVATE_KEY root@$IP_ADDRESS /bin/bash -c "'
docker pull boombatower/docker-backup-s3
###backup ERP from production
docker run --rm \
--volumes-from erpdata \
-e ACCESS_KEY="AKIAJSCML3VTEAVLR5RA" \
-e SECRET_KEY="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" \
-e BUCKET="s3://openb-erpdata/" \
-v $(pwd):/backup \
boombatower/docker-backup-s3 backup "$CUSTOMER_ID"'-erpdata-'"$(date +%d%b%y).tar.xz"
echo "$CLIENT_ID ERP backed up"
###backup NA from production
docker run --rm \
--volumes-from mongo \
-e ACCESS_KEY="AKIAJSCML3VTEAVLR5RA" \
-e SECRET_KEY="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" \
-e BUCKET="s3://openb-erpdata/" \
-v $(pwd):/backup \
boombatower/docker-backup-s3 backup "$CUSTOMER_ID"'-nextaction-'"$(date +%d%b%y).tar.xz"
echo "$CLIENT_ID NextAction backed up"
'"
HOST_NAME=$TEST_HOST_NAME
ROOT_URL=$TEST_ROOT_URL
MONGO_URL=$TEST_MONGO_URL
IP_ADDRESS="`tugboat info -n "$HOST_NAME" --attribute ip --porcelain`"
ssh -o "StrictHostKeyChecking no" -i $PRIVATE_KEY root@$IP_ADDRESS /bin/bash -c "'
docker pull boombatower/docker-backup-s3
### kill and load from backup ERP in test
docker rm -f erpdata erpnext &> /dev/null
docker create -v /home/frappe/frappe-bench/sites/site1.local/ -v /var/lib/mysql --name erpdata davidgu/erpnext
docker run --rm \
--volumes-from erpdata \
-e ACCESS_KEY="AKIAJSCML3VTEAVLR5RA" \
-e SECRET_KEY="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" \
-e BUCKET="s3://openb-erpdata/" \
boombatower/docker-backup-s3 restore "$CUSTOMER_ID"'-erpdata-'"$(date +%d%b%y).tar.xz"
docker run -d -p 3500:80 --name erpnext -e VIRTUAL_HOST='erp.'"$HOST_NAME" -e VIRTUAL_PORT="3500" --volumes-from erpdata davidgu/erpnext
### kill and load from backup Nextaction
docker rm -f mongo nextaction &> /dev/null
docker run -d -p 27017:27017 --name mongo -v /opt/mongo_data:/data/db mongo
docker run --rm \
--volumes-from mongo \
-e ACCESS_KEY="AKIAJSCML3VTEAVLR5RA" \
-e SECRET_KEY="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" \
-e BUCKET="s3://openb-erpdata/" \
-e TAR_OPTS="--verbose" \
boombatower/docker-backup-s3 restore "$CUSTOMER_ID"'-nextaction-'"$(date +%d%b%y).tar.xz"
docker run --name nextaction -d -e VIRTUAL_HOST="$HOST_NAME" -e VIRTUAL_PORT="4000" -e ROOT_URL='http://'"$HOST_NAME" -e MONGO_URL='mongodb://'"$HOST_NAME"':27017/nextaction' -v /opt:/bundle -p 4000:80 meteorhacks/meteord:base
echo "$TEST_HOST_NAME loaded with $PRODUCTION_HOST_NAME"
'"
}
restore_server() {
echo "Restore ERP: $RESTORE_ERPDATA"
echo "Restore NextAction: $RESTORE_NEXTACTION"
echo "Restoring into $HOST_NAME"
### kill and load from backup ERP in test
IP_ADDRESS="`tugboat info -n "$HOST_NAME" --attribute ip --porcelain`"
ssh -o "StrictHostKeyChecking no" -i $PRIVATE_KEY root@$IP_ADDRESS /bin/bash -c "'
docker pull boombatower/docker-backup-s3
docker rm -f erpdata erpnext &> /dev/null
docker create -v /home/frappe/frappe-bench/sites/site1.local/ -v /var/lib/mysql --name erpdata davidgu/erpnext
docker run --rm \
--volumes-from erpdata \
-e ACCESS_KEY="AKIAJSCML3VTEAVLR5RA" \
-e SECRET_KEY="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" \
-e BUCKET="s3://openb-erpdata/" \
boombatower/docker-backup-s3 restore "$RESTORE_ERPDATA"
docker run -d -p 3500:80 --name erpnext -e VIRTUAL_HOST='erp.'"$HOST_NAME" -e VIRTUAL_PORT="3500" --volumes-from erpdata davidgu/erpnext
### kill and load from backup Nextaction
docker rm -f mongo nextaction &> /dev/null
docker run -d -p 27017:27017 --name mongo -v /opt/mongo_data:/data/db mongo
docker run --rm \
--volumes-from mongo \
-e ACCESS_KEY="AKIAJSCML3VTEAVLR5RA" \
-e SECRET_KEY="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" \
-e BUCKET="s3://openb-erpdata/" \
boombatower/docker-backup-s3 restore "$RESTORE_NEXTACTION"
docker run --name nextaction -d -e VIRTUAL_HOST="$HOST_NAME" -e VIRTUAL_PORT="4000" -e ROOT_URL='http://'"$HOST_NAME" -e MONGO_URL='mongodb://'"$HOST_NAME"':27017/nextaction' -v /opt:/bundle -p 4000:80 meteorhacks/meteord:base
echo "$HOST_NAME loaded with $RESTORE_ERPDATA and $RESTORE_NEXTACTION"
'"
}
if [[ "$SERVER_DESTROY" = true ]]; then
server_destroy
fi
if [[ "$PRODUCTION_SETUP" = true ]]; then
HOST_NAME=$PRODUCTION_HOST_NAME
ROOT_URL=$PRODUCTION_ROOT_URL
MONGO_URL=$PRODUCTION_MONGO_URL
if [[ "$SPAWN_SERVERS" = true ]]; then
spawn_servers
fi
production_setup
erpnext_initial_setup
mongodb_initial_setup
nextaction_setup
fi
if [[ "$TEST_SETUP" = true ]]; then
HOST_NAME=$TEST_HOST_NAME
ROOT_URL=$TEST_ROOT_URL
MONGO_URL=$TEST_MONGO_URL
if [[ "$SPAWN_SERVERS" = true ]]; then
spawn_servers
fi
test_setup
erpnext_initial_setup
mongodb_initial_setup
nextaction_setup
fi
if [[ "$BACKUP_PRODUCTION" = true ]]; then
backup_production
fi
if [[ "$PRODUCTION_NEXTACTION" = true ]]; then
HOST_NAME=$PRODUCTION_HOST_NAME
ROOT_URL=$PRODUCTION_ROOT_URL
MONGO_URL=$PRODUCTION_MONGO_URL
nextaction_setup
fi
if [[ "$TEST_NEXTACTION" = true ]]; then
HOST_NAME=$TEST_HOST_NAME
ROOT_URL=$TEST_ROOT_URL
MONGO_URL=$TEST_MONGO_URL
nextaction_setup
fi
if [[ "$RESTORE_TEST_SERVER" = true ]]; then
HOST_NAME=$TEST_HOST_NAME
ROOT_URL=$TEST_ROOT_URL
MONGO_URL=$TEST_MONGO_URL
RESTORE_ERPDATA=$RESTORE_TEST_ERPDATA
RESTORE_NEXTACTION=$RESTORE_TEST_NEXTACTION
restore_server
fi
if [[ "$RESTORE_PRODUCTION_SERVER" = true ]]; then
HOST_NAME=$PRODUCTION_HOST_NAME
ROOT_URL=$PRODUCTION_ROOT_URL
MONGO_URL=$PRODUCTION_MONGO_URL
RESTORE_ERPDATA=$RESTORE_PRODUCTION_ERPDATA
RESTORE_NEXTACTION=$RESTORE_PRODUCTION_NEXTACTION
restore_server
fi