Linux: Montare una cartella remota con sshfs
Linux mette a disposizione molti sistemi per la connessione a file system remoti. SSHFS (Secure SHell FileSystem) è un filesystem che permette di condividere cartelle in modo sicuro tramite la connessione SSH. Nel PC locale, la risorsa remota verrà montato tramite FUSE (Filesystem in Userspace).
Premessa:
Ipotizziamo il seguente scenario:
- Sistema Locale: s1.local, IP address: 192.168.0.100
- Sistema Remoto: s2.local, IP address: 192.168.0.101
Ora vediamo come montare la directory remota /home/backup di s2 nella directory locale di s1 /backup. Tutto questo verrà fatto con l’utente root, anche se con piccole modifiche sarà possibile farlo gestire anche da un utente senza privilegi di root.
Iniziamo:
Innanzitutto bisogna installare sshfs nel Sistema Locale (s1):
1 |
apt-get install sshfs |
Aggiungiamo l’utente root al gruppo fuse:
1 |
adduser root fuse |
Creiamo la cartella /backup per montare il file system remoto:
1 2 |
mkdir /backup chown root /backup |
Montiamo il FileSystem remoto /home/backup nella cartella /backup:
1 |
sshfs -o idmap=user root@192.168.0.101:/home/backup /backup |
Nota: il codice -o idmap=user fa si che nel caso i sistemi abbiamo un differente user ID non ci siano problemi di permessi.
Dopo aver eseguito il precedente comando, verrà richiesta la password dell’utente root su s2 ed eventualmente di accettarne la chiave pubblica.
Digitanto ora “mount” si potrà verificare che la cartella remota sia stata montata:
1 2 3 4 5 |
mount ... ... /dev/sda1 on /boot type ext2 (rw) root@192.168.0.101:/home/backup on /backup type fuse.sshfs (rw,nosuid,nodev,max_read=65536) |
Ora, per smontare la cartella, basterà eseguire:
1 |
fusermount -u /backup |
Montaggio automatico all’avvio
Nel caso sia necessario montare il FileSystem remoto all’avvio, bisognerà caricare la chiave pubblica di s1 su s2 in modo che non venga più richiesta la password durante la connessione ssh.
Se non avete mai creato una chiave pubblica/privata su s1, basterà digitare su s1:
1 |
ssh-keygen |
e premere invio quando richiesto. Questo creerà la chiave pubblica in /root/.ssh/id_rsa.pub
Per copiare la chiave pubblica in s2, bisognerà digitare:
1 |
ssh-copy-id -i $HOME/.ssh/id_rsa.pub root@192.168.0.101 |
Per controllare che funzioni tutto correttamente, basterà effettuare un ssh verso s2 e verificare che non venga richiesta la password:
1 |
ssh root@192.168.0.101 |
Nota: solo come promemoria, ricordo che la chiave pubblica, con il comando ssh-copy-id viene copiata in $HOME/.ssh/authorized_keys di s2.
Benissimo, ci siamo quasi. Ora aggiungiamo al file /etc/rc.local le istruzioni per il montaggio del File System remoto, che verrà automaticamente effettuato al riavvio del sistema. Bisognerà inserire nel file /etc/rc.local, prima di un eventuale exit, la riga:
1 |
/usr/bin/sshfs -o idmap=user root@192.168.0.101:/home/backup /backup |
Ora basterà riavviare e verificare che il FileSystem sia stato correttamente montato.
enjoy!
Ti interessa acquistare un dominio a prezzi ultraconvenienti? clicca qui
Se hai trovato utili le informazioni su questo blog,
Fai una donazione!
Clicca sul bottone qui sotto o almeno clicca sul banner pubblicitario 🙂
Commenta