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