-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathinstall_spacemonclient.sh
257 lines (227 loc) · 9.74 KB
/
install_spacemonclient.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
#!/bin/sh
# 0.1.0 : Adapted from install_phedexagents.sh by Natalia Ratnikova
# version=0.1.0
install_spacemon-client_version=0.1.0
###################################################################
export VO_CMS_SW_DIR=/cvmfs/cms.cern.ch
export RELEASE=1.0.1
export REPO=comp
export SCRAM_ARCH=slc6_amd64_gcc493
cvmfs_server_name=$(grep cvmfs_server_name= $HOME/cron_install_cmssw.config | grep -v \# | cut -d= -f2)
cvmfs_server_name=$(eval echo $cvmfs_server_name)
notifytowhom=$(grep notifytowhom= $HOME/cron_install_cmssw.config | grep -v \# | cut -d= -f2)
RPMS=http://cmsrep.cern.ch/cmssw/${REPO}/RPMS/${SCRAM_ARCH}/
if [ $# -gt 0 ] ; then
if [ "x$1" != "x-" ] ; then
export VO_CMS_SW_DIR=$1
fi
fi
if [ $# -gt 1 ] ; then
if [ "x$2" != "x-" ] ; then
export RELEASE=$2
fi
fi
if [ $# -gt 2 ] ; then
if [ "x$3" != "x-" ] ; then
export REPO=$3
fi
fi
if [ $# -gt 3 ] ; then
if [ "x$4" != "x-" ] ; then
export SCRAM_ARCH=$4
fi
fi
RPMS=http://cmsrep.cern.ch/cmssw/${REPO}/RPMS/${SCRAM_ARCH}/
echo INFO $(basename $0) $VO_CMS_SW_DIR $RELEASE ${REPO} $RPMS
updated_list=$VO_CMS_SW_DIR/cvmfs-cms.cern.ch-updates
uname -a | grep -q "$cvmfs_server_name"
if [ $? -eq 0 ] ; then
cvmfs_server_yes=yes
fi
#
export MYTESTAREA=$VO_CMS_SW_DIR/spacemon-client # ~/tmp/spacemon-test # or wherever#
#
# #
###################################################################
grep -q "spacemon-client $RELEASE ${SCRAM_ARCH}" $updated_list
if [ $? -eq 0 ] ; then
echo Warning spacemon-client $RELEASE ${SCRAM_ARCH} installed according to $updated_list
exit 0
fi
# pre-check
echo "$SCRAM_ARCH" | grep -q slc[0-9]
if [ $? -ne 0 ] ; then
echo ERROR SCRAM_ARCH=$SCRAM_ARCH does not start with slc
printf "$(basename $0) SCRAM_ARCH=$SCRAM_ARCH does not start with slc\n" | mail -s "SCRAM_ARCH=$SCRAM_ARCH ERROR" $notifytowhom
exit 1
fi
i=0
if [ -d $MYTESTAREA ] ; then
echo INFO "[$i]" $MYTESTAREA exists
else
echo INFO "[$i]" creates $MYTESTAREA
mkdir -p $MYTESTAREA
fi
i=$(expr $i + 1)
# Check if bootstrap is needed for $arch
ls -al $MYTESTAREA/$SCRAM_ARCH/external/rpm/*/etc/profile.d/init.sh 2>/dev/null 1>/dev/null
if [ $? -eq 0 ] ; then
echo INFO "[$i]" bootstratp unnecessary for ${SCRAM_ARCH} in spacemon-client
else
printf "$(basename $0) downloading bootstrap for $SCRAM_ARCH \n" | mail -s "$(basename $0) downloading bootstrap" $notifytowhom
echo INFO "[$i]" downloading bootstrap.sh
wget -O $MYTESTAREA/bootstrap.sh http://cmsrep.cern.ch/cmssw/$REPO/bootstrap.sh
if [ $? -ne 0 ] ; then
echo ERROR bootstrap.sh download failed
exit 1
fi
i=$(expr $i + 1)
echo INFO "[$i]" executing bootstrap.sh
sh -x $MYTESTAREA/bootstrap.sh -architecture $SCRAM_ARCH -path $MYTESTAREA -repository $REPO setup
if [ $? -ne 0 ] ; then
echo ERROR bootstrap.sh failed
exit 1
fi
fi
CMSPKG="$MYTESTAREA/common/cmspkg -a $SCRAM_ARCH"
if [ -f $MYTESTAREA/common/cmspkg ] ; then
echo INFO We use cmspkg
else
(
cd /tmp
echo INFO downloading cmspkg.py
wget -O cmspkg.py https://raw.githubusercontent.com/cms-sw/cmspkg/production/client/cmspkg.py
[ $? -eq 0 ] || { echo ERROR wget cmspkg.py failed ; rm -f cmspkg.py ; cd - ; exit 1 ; } ;
python cmspkg.py --architecture $SCRAM_ARCH --path $MYTESTAREA --repository comp setup
status=$?
[ -f $MYTESTAREA/common/cmspkg ] || { echo ERROR cmspkg is not installed ; rm -f cmspkg.py ; exit 1 ; } ;
rm -f cmspkg.py
cd
exit $status
)
[ $? -eq 0 ] || { printf "$(basename $0) $MYTESTAREA/common/cmspkg does not exist\nUse \nsource $HOME/cron_install_cmssw-functions\ndeploy_cmspkg /cvmfs/cms.cern.ch/spacemon-client slc6_amd64_gcc494 comp\n" | mail -s "ERROR: $MYTESTAREA/common/cmspkg does not exist" $notifytowhom ; exit 1 ; } ;
fi
#
#source $(ls -t $MYTESTAREA/$SCRAM_ARCH/external/curl/*/etc/profile.d/init.sh | head -1) # cvmfs_server
i=$(expr $i + 1)
echo INFO "[$i]" executing $CMSPKG -y upgrade # apt-get upgrade
$CMSPKG -y upgrade # apt-get --assume-yes upgrade
status=$?
if [ $status -ne 0 ] ; then
echo ERROR $CMSPKG -y upgrade upgrade failed
exit 1
fi
# Check if mutex error exists
echo INFO check if mutex error exists
# First pick the right rpm
rpm_init_env=$(ls -t $MYTESTAREA/${SCRAM_ARCH}/external/rpm/*/etc/profile.d/init.sh | head -1)
if [ -f $rpm_init_env ] ; then
source $rpm_init_env
else
echo Warning $rpm_init_env does not exist
fi
echo INFO first which rpm"?: " $(which rpm)
rpm -qa --queryformat '%{NAME} %{RELEASE}' > $HOME/logs/rpm_qa_NAME_RELEASE.spacemon-client.${SCRAM_ARCH}.log 2>&1
grep "unable to allocate memory for mutex" $HOME/logs/rpm_qa_NAME_RELEASE.spacemon-client.${SCRAM_ARCH}.log | grep -q "resize mutex region"
if [ $? -eq 0 ] ; then
grep -q "mutex_set_max 10000000" $MYTESTAREA/${SCRAM_ARCH}/var/lib/rpm/DB_CONFIG
if [ $? -ne 0 ] ; then
echo INFO adding mutex_set_max 1000000 to $MYTESTAREA/${SCRAM_ARCH}/var/lib/rpm/DB_CONFIG
echo mutex_set_max 10000000 >> $MYTESTAREA/${SCRAM_ARCH}/var/lib/rpm/DB_CONFIG
echo INFO rebuilding the DB
rpmdb --define "_rpmlock_path $MYTESTAREA/${SCRAM_ARCH}/var/lib/rpm/lock" --rebuilddb --dbpath $MYTESTAREA/${SCRAM_ARCH}/var/lib/rpm 2>&1 | tee $HOME/logs/rpmdb_rebuild.spacemon-client.${SCRAM_ARCH}.log
fi
fi
i=$(expr $i + 1)
echo INFO "[$i]" executing $CMSPKG update # apt-get update
$CMSPKG update 2>&1 # apt-get --assume-yes update
status=$?
if [ $status -ne 0 ] ; then
echo ERROR $CMSPKG update failed
exit 1
fi
i=$(expr $i + 1)
echo INFO "[$i]" executing $CMSPKG -y install cms+spacemon-client+$RELEASE
$CMSPKG -y install cms+spacemon-client+$RELEASE > $HOME/logs/cmspkg_install_cms_spacemon-client_${SCRAM_ARCH}_$RELEASE.log 2>&1
status=$?
grep "unable to allocate memory for mutex" $HOME/logs/cmspkg_install_cms_spacemon-client_${SCRAM_ARCH}_$RELEASE.log | grep -q "resize mutex region"
if [ $? -eq 0 ] ; then
grep -q "mutex_set_max 10000000" $MYTESTAREA/${SCRAM_ARCH}/var/lib/rpm/DB_CONFIG
if [ $? -ne 0 ] ; then
echo INFO adding mutex_set_max 1000000 to $MYTESTAREA/${SCRAM_ARCH}/var/lib/rpm/DB_CONFIG
echo mutex_set_max 10000000 >> $MYTESTAREA/${SCRAM_ARCH}/var/lib/rpm/DB_CONFIG
echo INFO rebuilding the DB
rpmdb --define "_rpmlock_path $MYTESTAREA/${SCRAM_ARCH}/var/lib/rpm/lock" --rebuilddb --dbpath $MYTESTAREA/${SCRAM_ARCH}/var/lib/rpm 2>&1 | tee $HOME/logs/rpmdb_rebuild.spacemon-client.${SCRAM_ARCH}.log
fi
if [ $status -ne 0 ] ; then
echo INFO "[$i]" executing $CMSPKG -y install cms+spacemon-client+$RELEASE again after rebuilding the rpmdb after the mutex error
$CMSPKG -y install cms+spacemon-client+$RELEASE > $HOME/logs/cmspkg_install_cms_spacemon-client_${SCRAM_ARCH}_$RELEASE.log 2>&1
status=$?
fi
fi
cat $HOME/logs/cmspkg_install_cms_spacemon-client_${SCRAM_ARCH}_$RELEASE.log
if [ $status -ne 0 ] ; then
echo ERROR $CMSPKG -y install cms+spacemon-client+$RELEASE failed
echo Exiting from $(basename $0)
exit 1
fi
i=$(expr $i + 1)
echo INFO "[$i]" succefully executed $CMSPKG -y install cms+spacemon-client+$RELEASE
echo INFO checking $SCRAM_ARCH
if [ "x$cvmfs_server_yes" == "xyes" ] ; then
grep -q "spacemon-client $RELEASE ${SCRAM_ARCH}" $updated_list
if [ $? -eq 0 ] ; then
echo Warning spacemon-client $RELEASE ${SCRAM_ARCH} is already in the $updated_list
else
echo INFO adding spacemon-client $RELEASE ${SCRAM_ARCH} to $updated_list
echo spacemon-client $RELEASE ${SCRAM_ARCH} $(/bin/date +%s) $(/bin/date -u) >> $updated_list
fi
i=$(expr $i + 1)
echo INFO "[$i]" Check $updated_list for $RELEASE
echo INFO adding nested catalog
j=0
nslc=$(echo $MYTESTAREA/slc* | wc -w)
for thedir in $MYTESTAREA/slc* ; do
[ "x$thedir" == "x$MYTESTAREA/slc*" ] && break
[ -d $thedir ] || continue
j=$(expr $j + 1)
ls -al $thedir/.cvmfscatalog 2>/dev/null 1>/dev/null ;
if [ $? -eq 0 ] ; then
echo INFO "[ $j / $nslc ]" $thedir/.cvmfscatalog exists
else
echo INFO "[ $j / $nslc ]" creating $thedir/.cvmfscatalog
touch $thedir/.cvmfscatalog
fi
i=$(expr $i + 1)
echo INFO "[$i]" Check $thedir/.cvmfscatalog
echo INFO now further doing $spacemonclient_rel_dir/.cvmfscatalog
for spacemonclient_rel_dir in $thedir/cms/spacemon-client/* ; do
[ "x$spacemonclient_rel_dir" == "x$thedir/cms/spacemon-client/*" ] && break
[ -d $spacemonclient_rel_dir ] || continue
ls -al $spacemonclient_rel_dir/.cvmfscatalog 2>/dev/null 1>/dev/null ;
if [ $? -eq 0 ] ; then
echo INFO $spacemonclient_rel_dir/.cvmfscatalog exists
else
echo INFO creating $spacemonclient_rel_dir/.cvmfscatalog
touch $spacemonclient_rel_dir/.cvmfscatalog
fi
done
done
echo INFO publishing cvmfs
echo INFO publishing the installation in the cvmfs
currdir=$(pwd)
cd
time cvmfs_server publish 2>&1 | tee $HOME/logs/cvmfs_server+publish+spacemon-client+install.log
cd $currdir
status=$?
if [ $status -eq 0 ] ; then
printf "$(basename $0) cvmfs_server_publish OK \n$(cat $HOME/logs/cvmfs_server+publish+spacemon-client+install.log | sed 's#%#%%#g')\n" | mail -s "$(basename $0) cvmfs_server publish for spacemon-client install OK" $notifytowhom
else
echo ERROR failed cvmfs_server publish
printf "$(basename $0) cvmfs_server publish failed\n$(cat $HOME/logs/cvmfs_server+publish+spacemon-client+install.log | sed 's#%#%%#g')\n" | mail -s "$(basename $0) cvmfs_server publish failed" $notifytowhom
( cd ; cvmfs_server abort -f ; ) ; # cvmfs_server abort -f
exit 1
fi
#echo INFO publishing
fi # if [ "x$cvmfs_server_yes" == "xyes" ] ; then
exit $status