Linux Rsync Backup
Jump to navigation
Jump to search
Here is a first cut at a backup script which will pull from a linux host. It will create an SSH public key pair if none exists already, copy them to the Pre, then perform a complete rsync to the user's ~/palm directory. So far it works okay with the emulator.
Warning - Setting up a key pair in this manner will mean a user on your linux box can get your Pre as well.
Instructions
- Make sure you have rsync and openssh installed on your Linux box.
- Save the code below to a file on your linux box (eg, backup).
- Make it executable (eg, chmod a+x backup.
- Enable wifi on your Pre (you'll need its current IP address), or start your emulator.
- To try with your emulator
linuxbox$ ./backup localhost 5522 root found, using it reached the palm with ssh key receiving file list ... done ./ bin/ ... etc ...
- To run with the Pre over IP:
linuxbox$ ./backup 111.222.233.244 222 root
Note you may need to specify the user you created when you rooted the Pre instead. The user will need read access to the whole file tree.
Code
#!/bin/bash
die()
{
echo $@
exit 1;
}
[ $# -eq 3 ] || die "Usage: $0 palm_ip palm_port palm_user"
host=$1
port=$2
user=$3
strict='-o StrictHostKeyChecking=no'
pubkey='-o PreferredAuthentications=publickey'
dest="-p $port $user@$host"
[ -x /usr/bin/rsync ] || die no rsync, you should: sudo apt-get install rsync
if [[ ! -f ~/.ssh/id_dsa || ! -f ~/.ssh/id_dsa.pub ]]; then
echo we need to make an ssh keypair
ssh-keygen -q -t dsa -f ~/.ssh/id_dsa -N '' || die ssh-keygen failed
else
echo found, using it
fi
if ssh $strict $pubkey $dest ls /etc/palm > /dev/null; then
echo reached the palm with ssh key
else
echo need to copy local pubkey to palm
cmd='umask 077; test -d .ssh || mkdir .ssh ; cat >> .ssh/authorized_keys'
cat ~/.ssh/id_dsa.pub | ssh $strict $dest $cmd
if ssh $strict $pubkey $dest ls /etc/palm > /dev/null; then
echo second try good, reached the palm with ssh key
else
die could not use pubkey after installing it on the palm
fi
fi
rsync -avz --size-only --exclude proc/ --exclude dev/ --exclude sys/ \
-e "ssh -p $port $strict" $user@$host:/ ~/palm