]> git.sesse.net Git - backup.sh/blob - backup-nonpriv.sh
Englishify a bit.
[backup.sh] / backup-nonpriv.sh
1 #!/bin/sh
2
3 # Modifisert utgave av backup.sh som tar backup også på maskiner der kolje ikke har root.
4
5 #dirs
6 confdir=/home/backup/conf/           #configuration files
7 storagedir=/backup                   #mountpoint of huge disc
8 ###
9
10 #exclude-pattern
11 exclude=$confdir/exclude
12 [ ! -f $exclude ] && printf "tmp\ncore\n" > $exclude
13 ###
14
15 #syntax of remotestat:
16 #hostname:/directory/
17 remotestatf=$confdir/remotestat
18 [ -f $remotestatf ] && remotestat=`cat $remotestatf`
19 ###
20
21 PATH=/local/bin:$PATH:/store/bin
22 export PATH
23
24 #start the logfile
25 date
26 echo
27 echo "Exclude pattern:"
28 cat $exclude
29 echo
30 echo
31
32 umask 027
33
34 # The computers we want to back up
35 unixcomputers=`cat $confdir/computers.unix.nonpriv | grep -v ^# | grep -v ^$`
36 ###
37
38 # Backup only one computer, from command line?
39 if [ $1 ] ; then 
40   unixcomputers=$1
41 fi
42
43 #disse bør kunne varieres fra fs til fs?
44 maksantallfulle=3          #hvor mange fulle vi tar vare på (kan overstyres med conf)
45 dagermellomfulle=30        #antall dager før det er på tide med ny full
46 logw=40
47 ###
48
49 #lager datovariabeler
50 DATE=`date "+%Y%m%d%H%M"`            #format: touch
51 DATEs=`date "+%Y-%m-%d %H:%M"`       #format: tar
52 ###
53
54 #selve backupen
55 # krever at noen variabler er satt
56 # krever at vi er i rett katalog
57 backup()
58 {
59
60  printf "%-${logw}s %s\n" "$computer:$filesystem" "$backuplevel backup"
61
62  if [ "$backuplevel" = "daglig" ] || [ "$backuplevel" = "incremental" ]
63  then
64   lastd=`cat ../.date`
65   lastcmd="\"$lastd\""
66  else
67   lastcmd=""
68  fi
69
70  #expand the exclude-path for use with tar
71  exf=`ssh $username@$computer "ls ~/.backup/exclude"`
72
73  #We try to run tar on the remote computer
74  #    C is instead of 'cd $filesystem'
75  #    - is 'this directory'
76  #    l is 'stay in local filesystem
77  if `ssh $username@$computer "sudo /usr/local/sbin/output-encrypted-backup $filesystem $lastcmd" | dd of=$DATE.tmp 2>/dev/null` 
78  then
79   # perhaps it did work
80   mv $DATE.tmp $DATE.tgz.gpg
81
82   # FIXME: ignore the file lists for now
83
84   # fix perm
85   chmod 600 *tgz.gpg                  #only for us
86 #  chmod 644 *sdx *idx 2>/dev/null     #everyone can read
87
88    echo $DATEs > ../.date            &&
89    touch -t $DATE ../.date
90  else
91   #it did not work
92   rm $DATE.tmp 2>/dev/null
93   echo "$backuplevel backup of $computer:$filesystem failed and deleted"
94  fi
95
96 }
97
98 #Løper gjennom listen av unixmaskiner som vi skal ta backup av
99 for computer in $unixcomputers
100 do
101  
102  # find the user to do the non-root parts as 
103  if [ -f $confdir/username.$computer ] ; then
104    username=`cat $confdir/username.$computer`
105  else 
106    username=backup
107  fi
108
109  # Try to SSH to the computer without entering a password.
110  if `ssh -n -o NumberOfPasswordPrompts=0 $username@$computer /bin/true`; then
111   echo "Passwordless SSH to $username@$computer works."
112  else
113   echo "Could not use passwordless SSH to $username@$computer. Exiting."
114   exit 1;
115  fi
116  
117  # see if se have a local exclude file
118  if [ -f $confdir/exclude.$computer ] ; then
119    localexclude=$confdir/exclude.$computer
120    
121    echo
122    echo "Overriding local exclude pattern with:"
123    cat $localexclude
124    echo
125    echo
126  else 
127    localexclude=$exclude
128  fi
129  
130  localmaksantallfulle=$maksantallfulle
131  # Sjekk om det skal være et annet antall fulle backuper av en boks
132  if [ -f $confdir/maksfulle.$computer ] ; then
133    localmaksantallfulle=`cat $confdir/maksfulle.$computer`
134  fi
135  
136  #tømmer variabelen for sikkerhets skyld
137  filesystems=""
138
139  #Sjekker nest siste felt i fstab. Om det er 0 tar vi ikke backup
140  filesystems=`ssh -n $username@$computer "cat /etc/fstab" \
141   | grep -v nfs \
142   | grep -v "^#" \
143   | grep -v "^$" \
144   | awk '{ if ( $(NF-1) != "0" ) print $2}' `
145
146  #clean up our dir at this client
147  ssh $username@$computer "rm -r ~/.backup ; mkdir -m 700 ~/.backup"
148
149  #try to copy $exclude to $computer
150  scp $localexclude $username@$computer:~/.backup/exclude ||
151     echo "could not copy $localexclude to $computer :("
152
153  #try to copy preeexec and postexec if they exist
154  [ -f $confdir/preexec.$computer ] &&
155     scp $confdir/preexec.$computer  $username@$computer:~/.backup/preexec
156  [ -f $confdir/postexec.$computer ] &&
157     scp $confdir/postexec.$computer $username@$computer:~/.backup/postexec
158
159  #try to run preexec if it exist
160  ssh $username@$computer "[ -f ~/.backup/preexec ] && /bin/bash -x ~/.backup/preexec"
161
162  for filesystem in $filesystems
163  do
164   #lager en variant uten tegnet "/" eller $ (gjelder NT)
165   sfilesystem=`echo $filesystem | tr '\/\$' '__'`
166
167   #lager det som trengs av kataloger
168   mkdir -m 755 -p $storagedir/$computer/$sfilesystem/full 2>/dev/null
169   mkdir -m 755 -p $storagedir/$computer/$sfilesystem/daglig 2>/dev/null
170
171   #
172   echo $filesystem > ${storagedir}/${computer}/.${sfilesystem}.name 
173   chmod 644 ${storagedir}/${computer}/.${sfilesystem}.name
174
175   #set default backuplevel
176   backuplevel=daglig
177
178   if [ ! -f $storagedir/$computer/$sfilesystem/.date ]
179   then
180    #take the first full backup of this filesystem on this computer
181    backuplevel=full
182    echo $DATEs > $storagedir/$computer/$sfilesystem/.date
183   fi
184
185   #sjekker om det er på tide med en full
186   if 
187  [ -z "`find $storagedir/$computer/$sfilesystem/full/ -name \*tgz.gpg -mtime -$dagermellomfulle`" ]
188   then
189    backuplevel=full
190   fi
191  
192   #gå ned i rett katalog
193   cd $storagedir/$computer/$sfilesystem/$backuplevel || exit 1
194
195   #perform the actual backup
196   backup
197
198   #delete complete backups
199   mf=$(($localmaksantallfulle+1))
200
201   for full in `ls -1t $storagedir/$computer/$sfilesystem/full/*tgz.gpg | tail -n +$mf`
202   do
203    prefix=`echo $full | sed "s/\.[^.]*$//"`
204    echo "$computer:$filesystem sletter full $prefix (for mange)"
205    rm $prefix*
206   done
207
208   #delete incremental backups older than the oldest complete backup
209   oldf=`ls -t1 $storagedir/$computer/$sfilesystem/full/*tgz.gpg | tail -n 1`
210   find \
211      $storagedir/$computer/$sfilesystem/daglig \
212      -type f \
213      \! -newer $oldf \
214      -exec rm {} \;
215      #denne funker bare med gnu find
216      #-printf "$computer:$filesystem sletter daglig %f (for gammel)\n" \
217
218  done
219
220  #try to run postexec if it exist
221  ssh $username@$computer "[ -f ~/.backup/postexec ] && /bin/bash -x ~/.backup/postexec"
222
223 done
224
225 #create report
226 #/home/backup/report.sh $storagedir > /tmp/report.txt
227 #[ ! -z $remotestat ] && scp /tmp/report.txt $remotestat
228 ###
229
230 # print diskusage to logfile
231 df -k
232
233 date