forked from dmwm/deployment
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdeploy
77 lines (64 loc) · 1.96 KB
/
deploy
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
# vim: set ft=sh sw=2 ts=8 et :
deploy_workqueue_variants="default prod preprod dev"
deploy_workqueue_deps()
{
deploy couchdb
deploy bigcouch
}
deploy_workqueue_prep()
{
mkproj cache
}
deploy_workqueue_sw()
{
deploy_pkg \
-a dmwm-service-cert.pem:wmcore/dmwm-service-cert.pem \
-a dmwm-service-key.pem:wmcore/dmwm-service-key.pem \
comp cms+workqueue
if grep -rq "replace me" $project_auth; then
note "WARNING: replace certificates in $project_auth with real ones"
else :; fi
cp -p $project_config/GlobalWorkQueueConfig-${variant}.py $project_config/GlobalWorkQueueConfig.py
}
deploy_workqueue_post()
{
# Do cache cleanup
local cmd="rm -rf $root/state/workqueue/cache/*"
$nogroups || cmd="sudo -H -u _workqueue bashs -l -c \"${cmd}\""
eval $cmd
# Tell couch to push workqueue apps on the next restart
for couch in couchdb:5984 bigcouch:5985; do
echo "$project_config/workqueue_task pushcouchapp http://localhost:${couch##*:}" \
> $root/state/${couch%%:*}/stagingarea/workqueue
done
# Setup workqueue cronjobs
local manage=$root/current/config/workqueue/workqueue_task
local cmd="$manage reqmgr_sync"
$nogroups || cmd="sudo -H -u _workqueue bashs -l -c \"${cmd}\""
local req_sync="5-45/20 * * * * $cmd"
local cmd="$manage location_refresh"
$nogroups || cmd="sudo -H -u _workqueue bashs -l -c \"${cmd}\""
local locations="30 * * * * $cmd"
local cmd="$manage housekeep"
$nogroups || cmd="sudo -H -u _workqueue bashs -l -c \"${cmd}\""
local housekeep="15-55/20 * * * * $cmd"
(mkcrontab;
case $variant:$host in
prod:vocms0140 | preprod:vocms0131 | dev:vocms0127 | default:* )
echo "${req_sync}"
echo "${locations}"
echo "${housekeep}"
;;
* )
;;
esac) | crontab -
}
deploy_workqueue_auth()
{
case $1 in
*/*-cert.pem )
echo "replace me with your dmwm service certificate" ;;
*/*-key.pem )
echo "replace me with your dmwm service key" ;;
esac
}