- Estréllate y Arde - https://www.estrellateyarde.org -

Compartir archivos con otros Linux: NFS

NFS (Network File System) es un protocolo de red que permite montar un directorio de una máquina remota en nuestra máquina y trabajar en él como si fuera un directorio local. De esta manera podemos compartir un directorio (y todo lo que cuelga de él) con las demás máquinas Linux de nuestra red local.

El protocolo NFS se implementa con arquitectura cliente-servidor, por lo que necesita:

  • un servidor NFS en la máquina remota, la que exporta el directorio.
  • un cliente NFS en la máquina local, la que monta el directorio.

Recursos

NFS trabaja sobre RPC

El servidor NFS trabaja sobre RPC (Remote Procedure Call), protocolo que utiliza como capa de transporte UDP.

  • Los servidores que trabajan sobre RPC (como NFS), no tienen puertos asignados oficialmente, por lo que cuando arrancan, contactan con el daemon portmap y le informan de qué puerto usan.
  • Cuando un cliente quiere contactar con un servidor RPC, contacta primero con portmap (que escucha en el puerto 111 TCP) y le pregunta cuál es el puerto correspondiente al servidor en cuestión. Una vez que conoce ese dato, el cliente ya puede contactar directamente con el servidor.

Para ver los servicios RPC que tenemos activos y el puerto utilizado por cada uno, haremos:

$ rpcinfo -p

obteniendo (antes de instalar NFS) algo similar a:

programa vers proto puerto
 100000    2   tcp    111  portmapper
 100000    2   udp    111  portmapper
 100024    1   udp  32768  status
 100024    1   tcp  32899  status

Servidor NFS

  • Una vez instalado el servidor NFS (nfs.sourceforge.net, paquete nfs-kernel-server), editaremos el archivo de configuración /etc/exports para definir qué directorios exportamos y quién puede acceder. La sintaxis de /etc/exports es la siguiente:
    <directorio_exportado> <host_que_puede_acceder>(opciones)

    Por ejemplo:

    /home/francis 192.168.0.0/255.255.255.0(rw,sync)
    /home/sergio 192.168.0.2(ro,sync) 192.168.0.4(rw,sync)

    La opción ro es para sólo lectura y rw para lectura y escritura.

  • Guardamos los cambios y reiniciamos el servidor:
    # /etc/init.d/nfs-kernel-server restart
  • El servidor NFS tiene varios demonios, siendo los principales nfsd, rpc.mountd, rpc.statd y lockd.
  • Veamos los servicios RPC que tenemos activos una vez instalado el servidor NFS:
    $ rpcinfo -p
    programa vers proto puerto
     100000    2   tcp    111  portmapper
     100000    2   udp    111  portmapper
     100024    1   udp  32768  status
     100024    1   tcp  32899  status
     100003    2   udp   2049  nfs
     100003    3   udp   2049  nfs
     100003    4   udp   2049  nfs
     100003    2   tcp   2049  nfs
     100003    3   tcp   2049  nfs
     100003    4   tcp   2049  nfs
     100021    1   udp  32786  nlockmgr
     100021    3   udp  32786  nlockmgr
     100021    4   udp  32786  nlockmgr
     100021    1   tcp  59688  nlockmgr
     100021    3   tcp  59688  nlockmgr
     100021    4   tcp  59688  nlockmgr
     100005    1   udp    903  mountd
     100005    1   tcp    906  mountd
     100005    2   udp    903  mountd
     100005    2   tcp    906  mountd
     100005    3   udp    903  mountd
     100005    3   tcp    906  mountd
  • Para ver los directorios que están siendo compartidos haremos:
    # exportfs
  • Podemos saber los clientes NFS conectados mirando /var/lib/nfs/rmtab:
    $ cat /var/lib/nfs/rmtab

Cliente NFS

  • Para montar un directorio exportado usaremos mount, que es el cliente para NFS:
    # mount -t nfs 192.168.0.4:/home/francis /mnt
  • Lo desmontaremos con umount:
    # umount /mnt
  • Para montarlo durante el arranque añadiremos una línea a /etc/fstab:
    # File_system             Mount_point Type Options       Dump Pass
    192.168.0.4:/home/francis /mnt        nfs  rw,hard,intr  0    0

Article printed from Estréllate y Arde: https://www.estrellateyarde.org

URL to article: https://www.estrellateyarde.org/discover/nfs

Copyright © 2010 Estrellate y Arde