一篇干货满满的 NFS 文章

一篇干货满满的 NFS 文章,第1张

概述[TOC] NFS 1. 安装 2. 配置 主要配置文件: 示例配置: 表示 共享的目录,注意该目录的权限,如果我们设置好了其他的内容时,访问还是报错的话,我们可以试着将该目录的权限设置为 777。

目录NFS1. 安装@H_502_9@2. 配置NFS 指定端口@H_502_9@@H_502_9@3. 启动并添加到开机自启@H_502_9@4. NFS 客户端挂载@H_502_9@5 报错与解决办法5.1 NFS root 用户挂载但普通用户无写入权限。@H_502_9@5.2 网络错误 53 内容一@H_502_9@5.3 网络错误 53 内容二@H_502_9@5.4 网络错误 53 内容三@H_502_9@5.5 网络错误 53 内容四@H_502_9@5.6 网络错误 53 内容五@H_502_9@@H_502_9@6. Win 系统安装 NFS clientWindows 2008 server安装NFS Client所需软件@H_502_9@Win10 安装 NFS client@H_502_9@@H_502_9@@H_502_9@

NFS1. 安装
yum install nfs-utils  -y
2. 配置

主要配置文件: /etc/exports

示例配置:

/nfsfile 192.168.10.*(rw,sync,root_squash)

/nfsfile 表示 共享的目录,注意该目录的权限,如果我们设置好了其他的内容时,访问还是报错的话,我们可以试着将该目录的权限设置为 777。

@H_502_9@

192.168.10.*,指定 IP 允许访问,我们可以设置我们需要访问的客户端 IP 或者网段,不限制的话设置为 *

@H_502_9@

(rw,root_squash)

参数作用
ro只读
rw读写
root_squash当NFS客户端以root管理员访问时,映射为NFS服务器的匿名用户
no_root_squash当NFS客户端以root管理员访问时,映射为NFS服务器的root管理员
all_squash无论NFS客户端使用什么账户访问,均映射为NFS服务器的匿名用户
sync同步,同时将数据写入到内存与硬盘中,保证不丢失数据
async异步,优先将数据保存到内存,然后再写入硬盘;这样效率更高,但可能会丢失数据
anonuID匿名用户ID
anongID匿名组ID

请注意,NFS客户端地址与权限之间没有空格。

@H_502_9@NFS 指定端口
# 查看基础信息[root@djx ~]# rpcinfo  -p  localhost   program vers proto   port  service    100000    4   tcp    111  portmapper    100000    3   tcp    111  portmapper    100000    2   tcp    111  portmapper    100000    4   udp    111  portmapper    100000    3   udp    111  portmapper    100000    2   udp    111  portmapper    100005    1   udp  20048  mountd    100005    1   tcp  20048  mountd    100005    2   udp  20048  mountd    100005    2   tcp  20048  mountd    100005    3   udp  20048  mountd    100005    3   tcp  20048  mountd    100003    3   tcp   2049  nfs    100003    4   tcp   2049  nfs    100227    3   tcp   2049  nfs_acl    100003    3   udp   2049  nfs    100003    4   udp   2049  nfs    100227    3   udp   2049  nfs_acl    100021    1   udp  36449  nlockmgr    100021    3   udp  36449  nlockmgr    100021    4   udp  36449  nlockmgr    100021    1   tcp  40638  nlockmgr    100021    3   tcp  40638  nlockmgr    100021    4   tcp  40638  nlockmgr#指定 mountd  端口[root@djx ~]# [root@mail test]# grep  "PORT"  /etc/sysconfig/nfsLOCKD_TCPPORT=32803LOCKD_UDPPORT=32769MOUNTD_PORT=892STATD_PORT=662STATD_OUTGOING_PORT=2020# 上面的这些配置,原本默认是注释的,我们需要将# 去除,开启配置。然后我们 还需要在防火墙开启端口111和2049的tcp/udp,开启 tcp 端口 2020、662、892、32803,开启 udp 端口 32769[root@djx ~]# firewall-cmd  --add-port={111/tcp,111/udp,2049/tcp,2049/udp,32769/udp,2020/tcp,662/tcp,892/tcp,32803/tcp}  --permanent  [root@djx ~]# firewll-cmd  --reload [root@djx ~]# systemctl  restart nfs-server [root@djx ~]# rpcinfo -p   program vers proto   port  service    100000    4   tcp    111  portmapper    100000    3   tcp    111  portmapper    100000    2   tcp    111  portmapper    100000    4   udp    111  portmapper    100000    3   udp    111  portmapper    100000    2   udp    111  portmapper    100024    1   udp  49166  status    100024    1   tcp  58683  status    100005    1   udp    892  mountd    100005    1   tcp    892  mountd    100005    2   udp    892  mountd    100005    2   tcp    892  mountd    100005    3   udp    892  mountd    100005    3   tcp    892  mountd    100003    3   tcp   2049  nfs    100003    4   tcp   2049  nfs    100227    3   tcp   2049  nfs_acl    100003    3   udp   2049  nfs    100003    4   udp   2049  nfs    100227    3   udp   2049  nfs_acl    100021    1   udp  32769  nlockmgr    100021    3   udp  32769  nlockmgr    100021    4   udp  32769  nlockmgr    100021    1   tcp  32803  nlockmgr    100021    3   tcp  32803  nlockmgr    100021    4   tcp  32803  nlockmgr

我看到有些文章说还需要加配置 RQUOTAD_PORT ,但是我没有加该配置,也是可以的,我看 /etc/sysconfig/nfs 文件里面也是没有这个配置的,所以没有加,也可能是版本不一样,我的环境是 CentOS linux release 7.4.1708,nfs 版本为: nfs-utils-1.3.0-0.61.el7.x86_64

3. 启动并添加到开机自启

由于在使用NFS服务进行文件共享之前,需要使用RPC(Remote Procedure Call,远程过程调用)服务将NFS服务器的IP地址和端口号等信息发送给客户端。因此,在启动NFS服务之前,还需要顺带重启并启用rpcbind服务程序,并将这两个服务一并加入开机启动项中。

[root@djx ~]# systemctl restart rpcbind[root@djx ~]# systemctl enable rpcbind[root@djx ~]# systemctl restart nfs-server[root@djx ~]# systemctl enable nfs-server
4. NFS 客户端挂载

NFS客户端的配置步骤也十分简单。先使用showmount命令(以及必要的参数,见下表)查询NFS服务器的远程共享信息,其输出格式为“共享的目录名称 允许使用客户端地址”。

showmount命令中可用的参数以及作用

参数作用
-e显示NFS服务器的共享列表
-a显示本机挂载的文件资源的情况NFS资源的情况
-v显示版本号
[root@djx ~]# showmount -e 192.168.10.10Export List for 192.168.10.10:/nfsfile 192.168.10.*

然后在NFS客户端创建一个挂载目录。使用 mount 命令并结合-t参数,指定要挂载的文件系统的类型,并在命令后面写上服务器的IP地址、服务器上的共享目录以及要挂载到本地系统(即客户端)的目录。

[root@linuxprobe ~]# mkdir /nfsfile[root@linuxprobe ~]# mount -t nfs 192.168.10.10:/nfsfile /nfsfile

挂载成功后就应该能够顺利地看到在执行前面的 *** 作时写入的文件内容了。如果希望NFS文件共享服务能一直有效,则需要将其写入到fstab文件中:

[root@linuxprobe ~]# cat /nfsfile/readmewelcome to linuxprobe.com[root@linuxprobe ~]# vim /etc/fstab ## /etc/fstab# Created by anaconda on Wed May 4 19:26:23 2017## Accessible filesystems,by reference,are maintained under '/dev/disk'# See man pages fstab(5),findfs(8),mount(8) and/or blkID(8) for more info#/dev/mapper/rhel-root / xfs defaults 1 1UUID=812b1f7c-8b5b-43da-8c06-b9999e0fe48b /boot xfs defaults 1 2/dev/mapper/rhel-swap swap swap defaults 0 0/dev/cdrom /media/cdrom iso9660 defaults 0 0 192.168.10.10:/nfsfile /nfsfile nfs defaults 0 0
5 报错与解决办法5.1 NFS root 用户挂载但普通用户无写入权限。

最近在使用 NFS 的过程中遇到了这样的问题,就是我们挂载好共享的文件后(挂载只能 root 用户进行挂载),我们用普通用户来对挂载的目录进行创建文件是发现会报错的,会提示权限不足。

这个问题的解决办法是 :通过设置 anonuID=0anongID=0all_squash。这个设置实现了无论NFS客户端使用什么账户访问,均映射为NFS服务器的 ID 为 0 的用户,也就是 root 用户。这样普通用户也会有权限在该目录下面创建文件的权限,并且创建的文件的所有者是属于 root 的。

扩展: 当我们在客户端和服务端有相同的用户,而且 ID 一致的时候,我们可以 设置 anonuID 为一致的 ID。,这样我们创建文件的所有者就是 该 ID 的所对应的用户了。 注意需要 ID 一致哦。

5.2 网络错误 53 内容一

window连接linux nfs服务器 —— 网络错误 53

需要修改配置 ,增加参数: insecure

5.3 网络错误 53 内容二

针对的是 windows 2008 server作为客户端mount的时候

如果我们设置为上面的内容后,发现连接的时候还是报 53的错误。我们可以进行下面的第二步设置。

在 配置文件 /etc/exports 设置读写权限的时候 设置参数 no_root_squash,不设置这个不行。

更改配置后需要重启 nfs server 。

systemctl start nfs-server
5.4 网络错误 53 内容三

我们映射的目录权限最好为 777 ,否则可能访问不到。

5.5 网络错误 53 内容四

客户端进行 mount 路径有误。 看下面示例:

例如映射的 目录是 /home,那么 mount 的命令是 :

mount  \192.168.1.23\home  X:\   

例如映射的 目录是 /home/test,那么 mount 的命令是 :

mount  \192.168.1.23\home/test  X:\   

注意多级目录后面就不是使用 \ 而是用 /

5.6 网络错误 53 内容五

映射为本地的磁盘时,我们要选择我们没有使用的磁盘符。选用 X、Y、W等这些平常一般不使用的盘符号。

6. Win 系统安装 NFS clIEntwindows 2008 server安装NFS ClIEnt所需软件

通过Server Manager,

1.添加角色,选中file Services,然后按照向导提示安装。

2.添加Features,安装Remote Server administration Tools/Role administration Tools/file Services Tool/Services for Network file System Tools

需要安装Services For Network file System

然后运行Services For Network file system,启动clIEnt for NFS

Win10 安装 NFS clIEnt

总结

以上是内存溢出为你收集整理的一篇干货满满的 NFS 文章全部内容,希望文章能够帮你解决一篇干货满满的 NFS 文章所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/1015443.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存