AI智能
改变未来

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】设计模式之简单工厂模式、工厂模式、抽象工厂模式的对比

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

赞(0) 打赏
未经允许不得转载:爱站程序员基地 » Linux NFS挂载时候解决的记录