I have a network attached 1 Tb hard drive. It’s a white book, Western Digital “My Book World” device. I use it for backups. I needed to set it up to allow the backup scripts ssh access without a password. Here’s how I did it.
The web interface was used in the normal way to create a user named my_backups.
A share was set up automatically for this new user. The share name is the same as the user name - my_backups.
using advanced mode->network, I ensured that NFS was enabled and that only devices on my internal network were able to access the shares. This is not necesary for the backups though, but it allows me to NFS mount the share as required.
I logged onto the WD device using ssh, as root. I needed to edit the
/etc/passwdfile to move the home directory for my new user from/sharesto/shares/my_backupsotherwise, setttng up ssh affects (potentially) all users. And besides, I want my users to have their own home, not a shared one.The default permissions on the my_backups share is to allow group writes. Ssh will not work if this is the case, so that has to go, as root:
1chmod g-w /shares/my_backupsThe ownership of the my_backups share is also dubious. So another quick change is called for, as root:
1chown my_backups /shares/my_backupsNow I can login using ssh as the my_backups user, so logout as root, and back in again as my_backups.
Now set up all the stuff (technical term!) required by ssh:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18cd pwd /shares/my_backups mkdir .ssh backups chmod 600 .ssh ls -al ... drw------- 2 my_backu jewab 6 Feb 11 15:56 .ssh drwx------ 2 my_backu jewab 6 Feb 11 16:27 backups cd .ssh touch authorized_keys chmod 700 authorized_keys ls -l -rwx------ 1 my_backu jewab 0 Feb 11 15:58 authorized_keys exitNow, I copy my ssh public key to the new
authorized_keysfile, from my laptop, which is the device I’m backing up up to the shared drive:1 2 3$ cd ~/.ssh $ cat id_dsa.pub | ssh root@wd 'cat >> ~my_backups/.ssh/authorized_keys' root@wd's password: ******You will notice that I’m connecting as root to do this. For some reason, on the device, attempting to do this as my_backups gives me an error
sh: cannot create .ssh/authorized_keys: Permission deniedwhich is strange, as the file exists and is correctly owned by the my_backups user. However, there are a few foibles in the OS that is running on the device, so logging in as root works!Now I can login as my_backups without a password, from my laptop. And more to the point, my backup script can do it too.
1 2 3 4ssh my_backups@wd pwd /shares/my_backupsTalking of backup scripts, it’s nothing more than an
rsynccommand. The rsync option--archivecannot be used as it won’t let the--timespart of it run and lots of errors are scrolled up the screen.To get around this, I’m using
--perms --delete --update --verbose --links --progress --recursiveinstead. The destination on the rsync command is specified asmy_backups@wd:backupswhich does the job nicely!Ahem, of course, the first time I did this, I neglected to create the backups directory didn’t I? So what happened on the first actual run? Rsync happily
--deleted the .ssh directory holding my keys, so further testing didn’t work and requested the password that I had worked so hard to get rid of!