Ubuntu配置网络文件共享服务器NFS

来源:互联网 发布:淘宝不能卖pos 编辑:程序博客网 时间:2024/05/01 06:24
  环境:Ubuntu 8.04.3 LTS(2.6.24-24-generic) + nfs-kernel-server 1:1.1.2-4ubuntu1.1

  NFS服务器地址:192.168.0.2

  其中一台客户端地址:192.168.0.3

  1> 安装Ubuntu nfs

  Ubuntu上默认是没有安装Ubuntu nfs服务器的,因此我们首先安装Ubuntu nfs服务器端:

  roger@Ubuntu:/# apt-get install nfs-kernel-server

  在一些文档中,提出还需要使用apt-get来手动安装nfs的客户端nfs-common,以及端口映射器portmap,但其实这是没有必要的,因为在安装nfs-kernel-server时,apt会自动为我们把它们安装好。

  2> 配置/etc/exports

  Ubuntu nfs允许挂载的目录及权限在文件/etc/exports中进行了定义。

  例如,我们要将根目录下的rogerdir目录共享出来,那么我们需要在/etc/exports文件末尾添加如下一行:

  /rogerdir *(rw,sync,no_root_squash)

  其中:/rogerdir是要共享的目录,*代表允许所有的网络段访问(可以设置为192.168.0.3,只允许192.168.0.3访问),rw是可读写权限,sync是资料同步写入内存和硬盘,no_root_squash是 Ubuntu nfs客户端分享目录使用者的权限,如果客户端使用的是root用户,那么对于该共享目录而言,该客户端就具有root权限。

  其它Ubuntu nfs常用的参数有:

  ro 只读访问

  rw 读写访问sync 所有数据在请求时写入共享

  async nfs在写入数据前可以响应请求

  secure nfs通过1024以下的安全TCP/IP端口发送

  insecure nfs通过1024以上的端口发送

  wdelay 如果多个用户要写入nfs目录,则归组写入(默认)

  no_wdelay 如果多个用户要写入nfs目录,则立即写入,当使用async时,无需此设置。

  hide 在nfs共享目录中不共享其子目录

  no_hide 共享nfs目录的子目录

  subtree_check 如果共享/usr/bin之类的子目录时,强制nfs检查父目录的权限(默认)

  no_subtree_check 和上面相对,不检查父目录权限

  all_squash 共享文件的UID和GID映射匿名用户anonymous,适合公用目录。

  no_all_squash 保留共享文件的UID和GID(默认)

  root_squash root用户的所有请求映射成如anonymous用户一样的权限(默认)

  no_root_squas root用户具有根目录的完全管理访问权限

  anonuid=xxx 指定nfs服务器/etc/passwd文件中匿名用户的UID

  anongid=xxx 指定nfs服务器/etc/passwd文件中匿名用户的GID

  3> Ubuntu nfs重启服务

  roger@Ubuntu:/# /etc/init.d/nfs-kernel-server restart

  4、测试Ubuntu nfs

  此时可以运行以下命令来显示一下共享出来的目录:

  $showmount -e

  或者可以使用以下命令把它挂载在本地磁盘上,例如将/rootfs挂载到/mnt下:

  $ sudo mount -t nfs localhost:/rogerdir /mnt

  可以运行df命令查看是否挂载成功。查看后可以使用以下命令卸载:

  $ sudo umount /mnt

原创粉丝点击