Linux NFS挂载时候解决的记录

前言:

NFS环境搭建时候遇到的问题记录:

调试jetson-nano时候,需要互相传一些文件,本来是想用scp传输就好了,觉得不是很方便,就使用了nfs网络文件系统,在搭建环境使用过程中遇到一些问题,写这篇文章用来记录和分享,

搭建环境介绍

网络文件系统,常被称为NFS(Network File System),它是一种非常便 捷的在服务器与客户端通过网络共享文件的方式。

开启了NFS服务后,客户端访问服务器共享的文件时如同访问本 地存储器(磁盘/SD卡/NAND FLASH等)上的文件一样,,在嵌入式开发时,我们常常利用这个特性在主机上共享文件,主要应用场景如下:

搭建环境主要包含连接网络、主机开启NFS服务 以及从机挂载文件系统三个步骤。
其中,我本次挂载设备目录信息为:
服务主机共享目录为:/home/jetson/Pictures,
从机的挂载目录为:/home/lyn/jetson_nano/nfs_dir/。
主机IP:172.16.60.174 不过我在后续都以 jetson_nano 来映射了。

地一个任务是去互相ping挂载的对方,如果ping通再执行下一步。

使用此条命令执行挂载

sudo mount -t nfs jetson_nano:/home/jetson/Pictures  /home/lyn/jetson_nano/nfs_dir/

挂载遇到的问题

问题 1
mount.nfs: requested NFS version or transport protocol is not supported

主机没有安装NFS服务,需要使用如下命令安装NFS服务端软件:

安装nfsserver

sudo apt install nfs-kernel-server 


问题 2
sudo mount -t nfs jetson_nano:/home/jetson/Pictures /home/lyn/jetson_nano/nfs_dir/ mount.nfs: access denied by server while mounting jetson_nano:/home/jetson/Pictures

配置nfs服务端
安装 NFS 服务后,会新增一个 /etc/exports 文件,在 /etc/exports 文件末尾添加如下语句并保存。
vi /etc/exports添加以下内容: /home/jetson/Pictures 172.16.0.0/24(rw,sync,all_squash,anonuid=1000,anongid=1000,no_subtree_check) /home/jetson/Pictures *(insecure,rw,async,no_root_squash)


解释一下该命令下详细的信息

/home/jetson/Pictures 172.16.0.0/24(rw,sync,all_squash,anonuid=1000,anongid=1000,no_subtree_check)
/home/jetson/Pictures *(insecure,rw,async,no_root_squash)
  • /home/jetson/Pictures :要共享的开发主机目录,注意使用空格与后面的配置隔开。

  • 172.16.0.0/24:配置谁可以访问,其中的/24是掩码,此处表示24个1,即11111111.11111111.11111111.00000000, 即掩码是255.255.255.0。结合前面172.16.0.0表示此处配置IP为 172.16.*的主机均可以访问该目录,即局域网上的所有主机。
    若局域网是其它网段,请参考此处的配置,不能直接用星号表示,如欲配 置172.16.1.* 的局域网下所有机器都可以访问,则配置为 172.16.1.0/24
    这个配置域也可以直接写可访问的主机名,如把“172.16.0.0/24”替换为从机名“jetson-client”,则仅该从机能访问共享的目录。(此处可以使用showmount -e 查看)

  • rw: 表示客户机的权限,rw表示可读写,具体的权限还受文件系统的rwx及用户身份影响。

  • sync:资料同步写入到内存与硬盘中。

  • anonuid=1000:将客户机上的用户映射成指定的本地用户ID的用户,此处1000是主机用户的uid,此处请根据具体的主机用户uid进行配置。

  • anongid=1000: 将客户机上的用户映射成属于指定的本地用户组ID,此处1000是主机用户组gid,此处请根据具体的主机用户组gid进行配置。

  • no_subtree_check:不检查子目录权限,默认配置。

本地用户ID和本地用户 组ID可以使用id命令查看:

id


更新exports配置

sudo exportfs -arv

在这里插入图片描述
查看NFS共享情况

showmount -e

开始挂载操作

这个时候就可以正常挂载NFS文件系统了,只不过使用命令行挂载的操作属于临时挂载,设备在重启后需要重新挂载该NFS目录才能访问。

使用mount命令挂载NFS服务器的共享目录到从机/home/lyn/jetson_nano/nfs_dir/目录下:

注意:需要把下面的jetson_nano设置为用户实际网络环境下的NFS服务器IP,我此处的jetson_nano在hosts进行了映射,实际IP是172.16.60.174

以下命令在从机上运行

sudo mount -t nfs jetson_nano:/home/jetson/Pictures  /home/lyn/jetson_nano/nfs_dir/
  • -t nfs:指定挂载的文件系统格式为nfs。
  • jetson_nano:指定NFS服务器的IP地址。
  • /home/jetson/Pictures:指定NFS服务器的共享目录。
  • /home/lyn/jetson_nano/nfs_dir/:本地挂载目录,NFS服务器的共享目录映射到从机的 /home/lyn/jetson_nano/nfs_dir/

    若挂载成功,终端不会有输出。

取消挂载

sudo umount   nfs_dir/


作者:良知犹存,白天努力工作,晚上原创公号号主。公众号内容除了技术还有些人生感悟,一个认真输出内容的职场老司机,也是一个技术之外丰富生活的人,摄影、音乐 and 篮球。关注我,与我一起同行。

                              ‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧  END  ‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧

推荐阅读

【1】jetson nano开发使用的基础详细分享

【2】Linux开发coredump文件分析实战分享

【3】CPU中的程序是怎么运行起来的 必读

【4】cartographer环境建立以及建图测试

【5】设计模式之简单工厂模式、工厂模式、抽象工厂模式的对比

本公众号全部原创干货已整理成一个目录,回复[ 资源 ]即可获得。

posted @ 2022-03-06 20:13  良知犹存  阅读(484)  评论(0编辑  收藏  举报