mount命令+nfs挂载失败原因

 

Mount 命令[转]

mount [-afFhnrvVw] [-L<标签>] [-o<选项>] [-t<文件系统类型>] [设备名] [加载点]

用法说明:mount可将指定设备中指定的文件系统加载到Linux目录下(也就是装载点)。可将经常使用的设备写入文件/etc/fastab,以使系统在每次启动时自动加载。mount加载设备的信息记录在/etc/mtab文件中。使用umount命令卸载设备时,记录将被清除。

常用参数和选项:

-a 加载文件/etc/fstab中设置的所有设备。

-f 不实际加载设备。可与-v等参数同时使用以查看mount的执行过程。

-F 需与-a参数同时使用。所有在/etc/fstab中设置的设备会被同时加载,可加快执行速度。

-h 显示在线帮助信息。

-L<标签> 加载文件系统标签为<标签>的设备。

-n 不将加载信息记录在/etc/mtab文件中。

-o<选项> 指定加载文件系统时的选项。有些选项也可在/etc/fstab中使用。这些选项包括:

   async 以非同步的方式执行文件系统的输入输出动作。

   atime 每次存取都更新inode的存取时间,默认设置,取消选项为noatime。

   auto 必须在/etc/fstab文件中指定此选项。执行-a参数时,会加载设置为auto的设备,取消选为noauto。

   defaults 使用默认的选项。默认选项为rw、suid、dev、exec、anto nouser与async。

   dev 可读文件系统上的字符或块设备,取消选项为nodev。

   exec 可执行二进制文件,取消选项为noexec。

   noatime 每次存取时不更新inode的存取时间。

   noauto 无法使用-a参数来加载。

   nodev 不读文件系统上的字符或块设备。

   noexec 无法执行二进制文件。

   nosuid 关闭set-user-identifier(设置用户ID)与set-group-identifer(设置组ID)设置位。

   nouser 使一位用户无法执行加载操作,默认设置。

   remount 重新加载设备。通常用于改变设备的设置状态。

   ro 以只读模式加载。

   rw 以可读写模式加载。

   suid 启动set-user-identifier(设置用户ID)与set-group-identifer(设置组ID)设置位,取消为nosuid。

   sync 以同步方式执行文件系统的输入输出动作。

   user 可以让一般用户加载设备。

-r 以只读方式加载设备,与-o ro相同

-t<文件系统类型> 指定设备的文件系统类型。常用的选项说明有:

   minix Linux最早使用的文件系统。

   ext2 Linux目前的常用文件系统。

   msdos MS-DOS 的 FAT。

   vfat Win85/98 的 VFAT。

   nfs 网络文件系统。

   iso9660 CD-ROM光盘的标准文件系统。

   ntfs Windows NT的文件系统。

   hpfs OS/2文件系统。Windows NT 3.51之前版本的文件系统。

   auto 自动检测文件系统。

-v 执行时显示详细的信息。

-V 显示版本信息。

-w 以可读写模式加载设备,默认设置。

--------------------------------------------------------------------------------------------------

例: 

挂载nfs

mount -v -t nfs 192.168.128.11:/vmstorage /mnt/vm

--------------------------------------------------------------------------------------------------

NFS 挂载失败原因[待搜集]

1.挂载时若出现mount.nfs: Input/output error

解决:在客户端也需启动portmap服务 service portmap status[查看状态];service portmap start[启动]

 

2.在用nfs共享大文件或者挂载根文件系统时候出现下面的问题:

nfs: server 192.168.14.223 not responding

nfs: server 192.168.14.223 not responding

nfs: server 192.168.14.223 OK

但是共享小文件还是可以的。

问题的原因分析:

1、NFS 的默认传输协议是 UDP,而PC机与嵌入式系统通过UPD交互时就会出现严重的网卡丢包现象;

2、server机和目标机网卡传输速率冲突,使得目标机需要大量时间复制大量数据包,其实如果目标机的网卡速率够大,则不用分那么多包,也不会冲突。

问题的解决方案:

方法一:在客户端改用TCP协议,使用下面的命令,在mount命令中加上参数tcp

#mount -o tcp ,nolock 192.168.14.223:/nfs_root /mnt

也可这样干:

跟踪了fs/nfs/nfsroot.c的代码,发现在nfs作为根文件系统时,参数可以直接写在“nfsroot=”后面,每个参数用逗号隔开,如:

nfsroot=192.168.10.1:/rootfs,proto=tcp,nfsvers=3,nolock

这样就可以指定nfs使用tcp协议

方法二:指定传输速率(限定传输时一次读写的数据大小)

#mount -t nfs -o intr,nolock,rsize=1024,wsize=1024 192.168.14.223:/nfs_root /mnt

 

3.挂载时出卡在连接状态

解决:在确认网络连接无异常的情况下则可能是iptable或者网络防火墙阻拦了NFS使用的TCP和UDP的111以及2049端口.以ESX为例,在需要挂载NFS共享盘时首先需要编辑防火墙安全文件允许访问该端口.


你可能感兴趣的:(server,tcp,linux,防火墙,service,windows,linux学习)