GNU/Linux >> Linux Esercitazione >  >> Debian

Configurazione di un server e client NFS su Debian Wheezy

Questa guida spiega come configurare un server NFS e un client NFS su Debian Wheezy. NFS sta per File System di rete; tramite NFS, un client può accedere (leggere, scrivere) una condivisione remota su un server NFS come se fosse sul disco rigido locale. In questo tutorial, ti mostrerò due diverse esportazioni NFS, l'esportazione di una directory client che memorizza i file come utente nessuno/nogroup senza preservare i permessi del filesystem e un'esportazione della directory /var/www che conserva i permessi e la proprietà dei file, come richiesto su una configurazione del server di hosting.

1 Nota preliminare

Sto usando due sistemi Debian Wheezy qui:

  • Server NFS:server.example.com, indirizzo IP:192.168.0.100
  • Client NFS:client.example.com, indirizzo IP:192.168.0.101

2 Installazione di NFS

server:

Sul server NFS eseguiamo:

apt-get install nfs-kernel-server nfs-common

Quindi creiamo i collegamenti di avvio del sistema per il server NFS e lo avviamo:

cliente:

Sul client possiamo installare NFS come segue (questo è in realtà lo stesso che sul server):

apt-get install nfs-common

3 Esportazione di directory sul server

server:

Vorrei rendere le directory /home/client1 e /var/www accessibili al client per mostrare le due diverse modalità di accesso del server NFS. La directory /home/client1 è condivisa in modalità standard, quindi tutti i file scritti in questa directory vengono archiviati come utente nessuno e gruppo nogruppo. Per la directory /var/www utilizzo l'opzione no_root_squash che indica al server nfs di preservare i permessi e la proprietà dei file. Questo è ad es. richiesto quando si desidera esportare la directory /var/www di un server Web gestito con ISPConfig 3

Per prima cosa creerò la directory /home/client1

mkdir /home/client1
chown nobody:nogroup /home/client1
chmod 755 /home/client1

La directory /var/www esiste molto probabilmente sul tuo server. In caso contrario, crealo:

mkdir /var/www
chown root:root /var/www
chmod 755 /var/www

Ora dobbiamo modificare /etc/exports dove "esportiamo" le nostre condivisioni NFS. Specifichiamo /home/client1 e /var/www come condivisioni NFS e diciamo a NFS di accedere a /home/client1 come utente nessuno (per saperne di più su /etc/exports, il suo formato e le opzioni disponibili, dai un'occhiata a

man 5 exports

)

vi /etc/exports
/home/client1           192.168.0.101(rw,sync,no_subtree_check)
/var/www        192.168.0.101(rw,sync,fsid=0,crossmnt,no_subtree_check,no_root_squash)

(L'opzione no_root_squash consente di accedere a /var/www come root.)

Per applicare le modifiche in /etc/exports, riavviamo il server nfs del kernel

/etc/init.d/nfs-kernel-server restart

4 Montaggio delle condivisioni NFS sul Cliente

cliente:

Innanzitutto, creiamo le directory in cui vogliamo montare le condivisioni NFS, ad esempio:

mkdir -p /mnt/nfs/home/client1
mkdir -p /var/www

Se la directory /var/www esiste già sul tuo server, ferma Apache, rinomina la directory e crea una nuova directory vuota come mountpoint

/etc/init.d/apache2 stop
mv /var/www /var/www_bak
mkdir -p /var/www

Successivamente, possiamo montarli come segue:

mount 192.168.0.100:/home/client1 /mnt/nfs/home/client1
mount 192.168.0.100:/var/www /var/www

Ora dovresti vedere le due condivisioni NFS negli output di

df -h
[[email protected] ~]# df -h
Filesystem            Size  Used Avail Use% Mounted on
/dev/mapper/vg_server2-LogVol00
                      9.7G  1.7G  7.5G  18% /
tmpfs                 499M     0  499M   0% /dev/shm
/dev/sda1             504M   39M  440M   9% /boot
192.168.0.100:/home/client1   9.7G  1.7G  7.5G  19% /mnt/nfs/home/client1
192.168.0.100:/var/www
                      9.7G  1.7G  7.5G  19% /var/www
[[email protected] ~]#

e

mount
[[email protected] ~]# mount
/dev/mapper/vg_server2-LogVol00 on / type ext4 (rw)
proc on /proc type proc (rw)
sysfs on /sys type sysfs (rw)
devpts on /dev/pts type devpts (rw,gid=5,mode=620)
tmpfs on /dev/shm type tmpfs (rw)
/dev/sda1 on /boot type ext4 (rw)
none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
sunrpc on /var/lib/nfs/rpc_pipefs type rpc_pipefs (rw)
192.168.0.100:/home/client1 on /mnt/nfs/home/client1 type nfs (rw,vers=4,addr=192.168.0.100,clientaddr=192.168.0.101)
192.168.0.100:/var/www on /var/www type nfs (rw,vers=4,addr=192.168.0.100,clientaddr=192.168.0.101)
[[email protected] ~]#

5 Test

Sul client, ora puoi provare a creare file di test sulle condivisioni NFS:

cliente:

touch /mnt/nfs/home/client1/test.txt
touch /var/www/test.txt

Ora vai al server e controlla se riesci a vedere entrambi i file di prova:

server:

ls -l /home/client1/
[[email protected] ~]# ls -l /home/client1
total 0
-rw-r--r-- 1 nobody nogroup 0 Feb 02 16:58 test.txt
[[email protected] ~]#
ls -l /var/nfs
[[email protected] ~]# ls -l /var/www
total 0
-rw-r--r-- 1 root root 0 Feb 02 16:58 test.txt
[[email protected] ~]#

(Si prega di notare le diverse proprietà dei file di test:la condivisione NFS /home/client1 ha accesso come nessuno / nogroup ed è di proprietà di nessuno / nogroup; la condivisione /var/www ottiene l'accesso come root, quindi /var/www/test .txt è di proprietà dell'utente e del gruppo root.)

6 Montaggio di condivisioni NFS all'avvio

Invece di montare manualmente le condivisioni NFS sul client, puoi modificare /etc/fstab in modo che le condivisioni NFS vengano montate automaticamente all'avvio del client.

cliente:

Apri /etc/fstab e aggiungi le seguenti righe:

vi /etc/fstab
[...]
192.168.0.100:/home/client1  /mnt/nfs/home/client1   nfs      rw,sync,hard,intr  0     0
192.168.0.100:/var/www  /var/www   nfs      rw,sync,hard,intr  0     0

Invece di rw,sync,hard,intr puoi usare diverse opzioni di montaggio. Per saperne di più sulle opzioni disponibili, dai un'occhiata a

man nfs

Per verificare se il tuo /etc/fstab modificato funziona, smonta le condivisioni ed esegui mount -a:

umount /mnt/nfs/home/client1
umount /var/www
mount -a

Ora dovresti vedere le due condivisioni NFS negli output di

df -h
[[email protected] ~]# df -h
Filesystem            Size  Used Avail Use% Mounted on
/dev/mapper/vg_server2-LogVol00
                      9.7G  1.7G  7.5G  18% /
tmpfs                 499M     0  499M   0% /dev/shm
/dev/sda1             504M   39M  440M   9% /boot
192.168.0.100:/home/client1   9.7G  1.7G  7.5G  19% /mnt/nfs/home/client1
192.168.0.100:/var/www
                      9.7G  1.7G  7.5G  19% /var/www
[[email protected] ~]#

e

mount
[[email protected] ~]# mount
/dev/mapper/vg_server2-LogVol00 on / type ext4 (rw)
proc on /proc type proc (rw)
sysfs on /sys type sysfs (rw)
devpts on /dev/pts type devpts (rw,gid=5,mode=620)
tmpfs on /dev/shm type tmpfs (rw)
/dev/sda1 on /boot type ext4 (rw)
none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
sunrpc on /var/lib/nfs/rpc_pipefs type rpc_pipefs (rw)
192.168.0.100:/home/client1 on /mnt/nfs/home/client1 type nfs (rw,vers=4,addr=192.168.0.100,clientaddr=192.168.0.101)
192.168.0.100:/var/www on /var/www type nfs (rw,vers=4,addr=192.168.0.100,clientaddr=192.168.0.101)
[[email protected] ~]#

7 crediti

Questo tutorial si basa sul tutorial Centos NFS Server di Falko Timme.

  • Linux NFS:http://nfs.sourceforge.net/
  • Debian:http://www.debian.org/

Debian
  1. Installazione di server e client NFS su CentOS 7

  2. Configurazione di un server e client NFS su Debian 9 (Stretch)

  3. Configurazione di un server e client NFS su CentOS 6.3

  4. Configurazione di un server e client NFS su OpenSUSE 12.2

  5. Differenza tra /var/log/messages, /var/log/syslog e /var/log/kern.log?

Come installare e configurare il server NFS su Debian 11

Come installare Server e Client NFS su Ubuntu

Come configurare client e server NFS su Linux

Come configurare server e client NTP su Debian 10

Come configurare server e client NTP su Debian 11

Come configurare Server e Client NFS su Debian 10