在CentOS 6.3上设置NFS服务器和客户端

在CentOS 6.3上设置NFS服务器和客户机

本指南介绍如何在CentOS 6.3上设置NFS服务器和NFS客户机。 NFS代表网络文件系统 ; 通过NFS,客户端可以访问(读取,写入)NFS服务器上的远程共享,就像它在本地硬盘上一样。

1初步说明

我在这里使用两个CentOS系统:

  • NFS服务器: server.example.com ,IP地址: 192.168.0.100
  • NFS客户端: client.example.com ,IP地址: 192.168.0.101

2安装NFS

服务器:

在NFS服务器上运行:

yum install nfs-utils nfs-utils-lib

然后我们为NFS服务器创建系统启动链接并启动它:

chkconfig --levels 235 nfs on 
/etc/init.d/nfs start

客户:

在客户端,我们可以按如下方式安装NFS(这实际上和服务器上的一样):

yum install nfs-utils nfs-utils-lib

3在服务器上导出目录

服务器:

我想让目录/ home/ var / nfs可以访问客户端; 因此我们必须在服务器上“导出”它们。

当客户端访问NFS共享时,通常会发生用户nobody 。 通常, / home目录不是由任何人拥有(我不建议将其所有权更改为nobody !),并且因为我们想在/ home上进行读写 ,所以告诉NFS应该以root身份进行访问如果我们的/ home分享是只读的,这是不必要的)。 / var / nfs目录不存在,所以我们可以创建它并更改其所有权; 在我的测试中,用户和组没有人在我的CentOS测试系统(服务器和客户端)上都有ID 99; 当我尝试从NFS客户端写入/ var / nfs时,我得到一个权限被拒绝的错误,所以我做了一个chmod 777 / var / nfs ,以便每个人都可以写入该目录; 从客户端写入/ var / nfs的工作,客户端写入/ var / nfs的文件似乎是由用户和组nobody拥有的,但是在服务器上它们是由(不需要的)用户和组所拥有的ID为65534 ; 所以我将/ var / nfs的所有权更改为服务器上的用户/组65534 ,并将/ var / nfs的权限更改为755 ,并且voilà允许客户端写入/ var / nfs

mkdir /var/nfs
chown 65534:65534 /var/nfs
chmod 755 /var/nfs

现在我们必须修改/ etc / exports我们“export”我们的NFS共享。 我们将/ home/ var / nfs指定为NFS共享,并告诉NFS以root身份访问/ home (要了解有关/ etc / exports ,其格式和可用选项的更多信息,请查看

man 5 exports

vi /etc/exports
/home           192.168.0.101(rw,sync,no_root_squash,no_subtree_check)
/var/nfs        192.168.0.101(rw,sync,no_subtree_check)

no_root_squash选项使得/ home将以root身份访问。)

每当我们修改/ etc / exports ,我们必须运行

exportfs -a

之后使变更生效。

4在客户端上挂载NFS共享

客户:

首先,我们创建要挂载NFS共享的目录,例如:

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

之后,我们可以挂载如下:

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

您现在应该看到这两个NFS共享的输出

df -h
[root@client ~]# 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   9.7G  1.7G  7.5G  19% /mnt/nfs/home
192.168.0.100:/var/nfs
                      9.7G  1.7G  7.5G  19% /mnt/nfs/var/nfs
[root@client ~]#

mount
[root@client ~]# 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 on /mnt/nfs/home type nfs (rw,vers=4,addr=192.168.0.100,clientaddr=192.168.0.101)
192.168.0.100:/var/nfs on /mnt/nfs/var/nfs type nfs (rw,vers=4,addr=192.168.0.100,clientaddr=192.168.0.101)
[root@client ~]#

5测试

在客户端上,您现在可以尝试在NFS共享上创建测试文件:

客户:

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

现在去服务器,检查是否可以看到这两个测试文件:

服务器:

ls -l /home/
[root@server ~]# ls -l /home/
total 0
-rw-r--r-- 1 root root 0 Dec 11 16:58 test.txt
[root@server ~]#
ls -l /var/nfs
[root@server ~]# ls -l /var/nfs
total 0
-rw-r--r-- 1 nfsnobody nfsnobody 0 Dec 11 16:58 test.txt
[root@server ~]#

(请注意测试文件的不同所有权: / home NFS共享以root身份访问,因此/home/test.txt由root拥有; / var / nfs共享作为nobody / 65534访问,因此/ var / nfs / test.txt65534拥有。)

6在启动时挂载NFS共享

您可以修改/ etc / fstab ,而不是在客户机上手动安装NFS共享,以便在客户端启动时自动挂载NFS共享。

客户:

打开/ etc / fstab并附加以下行:

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

代替 rw,sync,hard,intr 您可以使用不同的安装选项。 要了解有关可用选项的更多信息,请查看

man nfs

要测试您的/ etc / fstab是否正常工作,请重新启动客户端:

reboot

重新启动后,您应该在其输出中找到两个NFS共享

df -h
[root@client ~]# 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   9.7G  1.7G  7.5G  19% /mnt/nfs/home
192.168.0.100:/var/nfs
                      9.7G  1.7G  7.5G  19% /mnt/nfs/var/nfs
[root@client ~]#

mount
[root@client ~]# 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 on /mnt/nfs/home type nfs (rw,sync,hard,intr,vers=4,addr=192.168.0.100,clientaddr=192.168.0.101)
192.168.0.100:/var/nfs on /mnt/nfs/var/nfs type nfs (rw,sync,hard,intr,vers=4,addr=192.168.0.100,clientaddr=192.168.0.101)
[root@client ~]#

7链接

赞(52) 打赏
未经允许不得转载:优客志 » 系统运维
分享到:

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏