Differenze tra le versioni di "Old:NFS: Networking FileSystem tramite nfs-user-server"

Da Guide@Debianizzati.Org.
Jump to navigation Jump to search
m (piccole formattazioni)
m
Riga 1: Riga 1:
Beh, non tutti possono fare a meno di
+
==Come creare una directory shared tra macchine linux (nfs, acronimo di Network File System)==
 
 
 
  
, lilo, gag, etc. etc.) e gestire tutto tramite quello;<br>
+
Per far comunicare due macchine Linux, è possibile in diversi metodi: il modo più veloce per fare tutto ciò, è utilizzare NFS per mettere in condivisione una particolare directory del filesystem ad altri client.<br>
# Usare il bootloader di Windows, per avviare anche gli altri OS a cui siamo interessati;<br>
+
Di seguito è descritta una semplice procedura per configurare ed avviare il daemon di nfs sul server e per istruire il client a raggiungere la directory esportata: questa non vuole essere una guida esaustiva ad nfs, ma solo una breve descrizione di come risolvere velocemente lo scambio di dati tra macchiine linux.
  
Questo articolo prova a spiegare in modo semplice come impostare ed utilizzare il secondo metodo.<br>
 
Lo spunto e le nozioni riportate derivano dall'articolo di '''Rover''' presente a [http://www.littlewhitedog.com/content-52.html questo indirizzo].
 
  
+
=== Impostazione del Server ===
Durante l'un bootloader (di solito LILO o grub) e
+
Dopo aver installato con apt-get i pacchetti '''nfs-user-server''' (un linux daemon che lavora in userspace) e '''portmap''', bisogna modificare il file '''/etc/exports''' (in caso esso non esista, bisogna crearlo) aggiungendo una riga per ogni directory che si vuole esportare.<br>
In altre parole, il famoso '''MBR''', ovvero il Master Boot Record), in una partizione ben precisa o in un floppy.
 
  
Visto che siamo decisi a lasciare al boot loader di Windows l'onere di necessario per il momento scegliere la terza opzione (/dev/fd0), tenendo a mente di dover installare successivamente il boot loader sul disco.
+
{{Box | Nota |Portmap viene impostato di default ad essere "bindato" sul solo indirizzo di localhost, mentre l'uso consueto è diretto verso una o più reti lan. Per permettere alle varie reti di accedere al server è necessario modificare (oppure eliminare, per permettere un accesso completo) il parametro '''OPTIONS''', presente nel file '''/etc/default/portmap''' }}
, e noi utilizzeremo il disco floppy appena creato per rientrare nel nostro sistema.<br>
 
Al login accediamo come superutente e provvediamo a configurare il bootloader sul disco fisso usando il comando '''grub-install''' e specifando al partizione del nostro disco, corrispondente alla / del sistema linux.<br>
 
Ad esempio, nel mio caso ho:
 
  
/dev/hda7 ---> /
+
Un esempio di entry per il file export può essere:
/dev/hda6 ---> /home
 
  
quindi devo scegliere /dev/hda7.<br>
+
<pre>/mnt/Data/download 192.168.2.3 (rw)</pre>  
 
<pre>#grub-install /dev/hda7</pre>
 
.<br>
 
A questo punto possiamo disconnetterci come superutente (comando '''logout''') e rientrare come utente semplice.<br>
 
Dopo aver aperto una shell eseguite questo comando:
 
  
<pre>$ dd if=/dev/hda7 bs=512 count=1 of=/home/USER/linux.bin</pre>
+
in cui
 +
* '''/mnt/Data/download''' è la directory da esportare
 +
* '''192.168.2.3'''        è il client che può raggiungere la directory in questione;
 +
* '''(rw)'''              sono le opzioni impostabili ('''rw''':permessi di scrittura/lettura);
  
+
Qualora, invece, volessimo esportare la directory a tutte le macchine presenti all'interno di una sottorete:
, contenente i primi 512 byte della nostra partizione /, la stessa in cui, guarda caso, abbiamo installato il bootloader.<br>
 
 
Sempre dalla shell, copiamo '''linux.bin''' su un floppy vuoto, precendentemente inserito nell'apposito lettore con
 
  
<pre>$ mcopy /home/USER/linux.bin a:</pre>
+
<pre>/mnt/Data/download    192.168.0.1/255.255.255.0(rw)</pre>
  
NB: '''mcopy''' fa parte del pacchetto degli '''mtools''', nel caso non fosse installato e possibile usare i metodi standard di mount del device e di copia di un file.<br>
+
{{Box | Nota |Nelle nuove versioni di nfs è necessario inserire un flag aggiuntivo ('''sync''' oppure '''async''') per definire la modalità di accesso ed uso dei file.
Nel caso non si disponga di un drive floppy, e possibile usare un qualsiasi supporto utilizzabile in scrittura da Linux (una partizione di fat32, una pen drive, un cdrw, etc etc)<br>
+
'''Sync''' forza la scrittura immediata dei dati man mano che questi arrivano al server, mentre '''async''' consente di scrivere tali dati in intervalli successivi, migliorando così le performance del trasferimento.
A questo punto dobbiamo riavviare il non rilevi la presenza di Linux.
+
Vista la peculiarità di questo tipo di trasferimento è conveniente usare '''sync''' nelle situazioni di rw, ed '''async''' in quelle di ro, in modo da eliminare il pericolo di dati non salvati correttamente (e quindi persi) durante le fasi di scrittura nel caso di crash del server. }}
Una volta loggati come utente Administrator o equivalente, possiamo dedicarci alle modifiche.
 
  
file nascosto '''boot., come ad esempio c:\ .<br>
+
E' possibile inoltre definire gli accessi in modo più granulare utilizzando i file /etc/host.access e /etc/host.denied, ma per un uso basilare di nfs non è necessario applicare alcuna modifica.
Una volta attivata la '''visualizzazione dei file nascosti''' e quella dei '''file di .<br>
 
 
  
<pre>  [boot loader]
+
=== Impostazione del Client ===
    timeout=15
+
Bisogna innanzitutto installare '''nfs-common''' con apt-get, e successivamente modificare il proprio '''/etc/fstab''', aggiungendo una entry relativa alla directory che si vuole raggiungere via nfs; ad esempio:
    default=multi(0)disk(0)rdisk(0)partition(1)\WINDOWS
 
    [operating systems]
 
    multi(0)disk(0)rdisk(0)partition(1)\WINDOWS="Microsoft Windows XP Professional" /fastdetect</pre>
 
  
 +
<pre>192.168.2.2:/mnt/Data/download  /mnt/nfs nfs rw,users,noauto  0  0</pre>
  
la seguente riga:
+
in cui
 +
*    '''<tt>192.168.2.2:/mnt/Data/download</tt>''' &nbsp;&nbsp;&nbsp;  è la url completa della directory da raggiungere (sintassi, ip:path);
 +
*    '''<tt>/mnt/nfs</tt>''' &nbsp;&nbsp;&nbsp;  è la directory dove si vuole montare il device (la directory deve essere stata creata precendentemente);
 +
*    '''<tt>nfs</tt>''' &nbsp;&nbsp;&nbsp;  identifica il tipo di filesystem da usare (in questo caso nfs, filesystem di rete);
 +
*    '''<tt>rw,users,noauto</tt>'''  &nbsp;&nbsp;&nbsp;  sono i flag di mount del device (rw: permessi di scrittura/lettura, users: device montabile e smontabile dai vari user, noauto: device da non avviare automaticamente al boot del sistema);
 +
*    '''<tt>0 0</tt>''' &nbsp;&nbsp;&nbsp;  sono i flag relativi al check del device da parte dei programmi di controllo della coerenza del filesystem.
  
<pre>c:\linux.bin="Linux"</pre>
+
A questo punto basta un semplice
  
personalizzabile sia nel nome del file (linux.bin) che nell'etichetta da visualizzare (Linux).<br>
+
<pre>$ mount /mnt/nfs</pre>  
Preleviamo il file '''linux.bin''' che abbiamo prodotto con il comando '''dd''' e copiamolo nella directory c:\ .<br>
 
 
Una volta selezionata quest'ultima voce, ci troviamo davanti il bootloader fornito dall'istallazione di Linux.
 
  
, ma a mio avviso consente di , visto che quest''MBR per far posto al LILO o grub di turno.<br>
+
per poter usare normalmente la share nfs, come una normale directory del sistema.
E, finora, questo metodo non mi ha '''MAI''' abbandonato!<br>
+
 
 +
In caso di malfunzionamenti inoltre, è possibile controllare lo stato della share nfs sia dal client che dal server, utilizzando le applicazioni '''rpcinfo''' e '''nfsstat''' in modo da verificare visualmente le risorse condivise attive nella rete.
 +
 
 +
----
  
 
[[Utente:Ldonesty|Ldonesty]]
 
[[Utente:Ldonesty|Ldonesty]]
 +
[[Categoria:Networking]][[Categoria:Desktop]]

Versione delle 21:05, 1 apr 2006

Come creare una directory shared tra macchine linux (nfs, acronimo di Network File System)

Per far comunicare due macchine Linux, è possibile in diversi metodi: il modo più veloce per fare tutto ciò, è utilizzare NFS per mettere in condivisione una particolare directory del filesystem ad altri client.
Di seguito è descritta una semplice procedura per configurare ed avviare il daemon di nfs sul server e per istruire il client a raggiungere la directory esportata: questa non vuole essere una guida esaustiva ad nfs, ma solo una breve descrizione di come risolvere velocemente lo scambio di dati tra macchiine linux.


Impostazione del Server

Dopo aver installato con apt-get i pacchetti nfs-user-server (un linux daemon che lavora in userspace) e portmap, bisogna modificare il file /etc/exports (in caso esso non esista, bisogna crearlo) aggiungendo una riga per ogni directory che si vuole esportare.

Info.png Nota
Portmap viene impostato di default ad essere "bindato" sul solo indirizzo di localhost, mentre l'uso consueto è diretto verso una o più reti lan. Per permettere alle varie reti di accedere al server è necessario modificare (oppure eliminare, per permettere un accesso completo) il parametro OPTIONS, presente nel file /etc/default/portmap


Un esempio di entry per il file export può essere:

/mnt/Data/download 192.168.2.3 (rw)

in cui

  • /mnt/Data/download è la directory da esportare
  • 192.168.2.3 è il client che può raggiungere la directory in questione;
  • (rw) sono le opzioni impostabili (rw:permessi di scrittura/lettura);

Qualora, invece, volessimo esportare la directory a tutte le macchine presenti all'interno di una sottorete:

/mnt/Data/download    192.168.0.1/255.255.255.0(rw)
Info.png Nota
Nelle nuove versioni di nfs è necessario inserire un flag aggiuntivo (sync oppure async) per definire la modalità di accesso ed uso dei file.

Sync forza la scrittura immediata dei dati man mano che questi arrivano al server, mentre async consente di scrivere tali dati in intervalli successivi, migliorando così le performance del trasferimento. Vista la peculiarità di questo tipo di trasferimento è conveniente usare sync nelle situazioni di rw, ed async in quelle di ro, in modo da eliminare il pericolo di dati non salvati correttamente (e quindi persi) durante le fasi di scrittura nel caso di crash del server.


E' possibile inoltre definire gli accessi in modo più granulare utilizzando i file /etc/host.access e /etc/host.denied, ma per un uso basilare di nfs non è necessario applicare alcuna modifica.

Impostazione del Client

Bisogna innanzitutto installare nfs-common con apt-get, e successivamente modificare il proprio /etc/fstab, aggiungendo una entry relativa alla directory che si vuole raggiungere via nfs; ad esempio:

192.168.2.2:/mnt/Data/download  /mnt/nfs nfs rw,users,noauto   0   0

in cui

  • 192.168.2.2:/mnt/Data/download     è la url completa della directory da raggiungere (sintassi, ip:path);
  • /mnt/nfs     è la directory dove si vuole montare il device (la directory deve essere stata creata precendentemente);
  • nfs     identifica il tipo di filesystem da usare (in questo caso nfs, filesystem di rete);
  • rw,users,noauto     sono i flag di mount del device (rw: permessi di scrittura/lettura, users: device montabile e smontabile dai vari user, noauto: device da non avviare automaticamente al boot del sistema);
  • 0 0     sono i flag relativi al check del device da parte dei programmi di controllo della coerenza del filesystem.

A questo punto basta un semplice

$ mount /mnt/nfs

per poter usare normalmente la share nfs, come una normale directory del sistema.

In caso di malfunzionamenti inoltre, è possibile controllare lo stato della share nfs sia dal client che dal server, utilizzando le applicazioni rpcinfo e nfsstat in modo da verificare visualmente le risorse condivise attive nella rete.


Ldonesty