在线课堂:https://www.100ask.net/index(课程观看)
论  坛:http://bbs.100ask.net/(学术答疑)
开 发 板:https://100ask.taobao.com/ (淘宝)
     https://weidongshan.tmall.com/(天猫)
交流群一:QQ群:869222007(鸿蒙开发/Linux/嵌入式/驱动/资料下载)
交流群二:QQ群:536785813(单片机-嵌入式)
公 众 号:百问科技


版本 日期 作者 说明
V1 2020 韦东山 摘自《嵌入式Linux应用开发完全手册》

在第一期视频 :
第0课第7节_刚接触开发板之制作根文件系统及初试驱动.wmv ,因为要测试驱动,所以必须要把驱动程序弄到开发板里才行。
于是韦老师介绍了两种方式:

#1 仅用flash上的根文件系统启动后,手工MOUNT NFS
使用NFS作为根文件系统来启动

视频中只介绍了开发板这端uboot参数的设置,并未介绍Ubuntu端 NFS服务器的设置,这就导致很多学员学习时遇到难以逾越的问题:NFS挂载,从而影响学习进度和热情。此帖就是解决NFS相关的问题,希望对初学者有所帮助。先介绍:1 仅用flash上的根文件系统启动后,手工MOUNT NFS, 前提条件:

  1. 开发板上要烧写好文件系统
  2. 能正常开机进入Linux系统
    3.uboot中启动参数类似这种 bootargs=noinitrd root=/dev/mtdblock3 init=/linuxrc console=ttySAC0

大概说下步骤:
##1.搭建(下载)、配置和重启NFS服务器
##2.Ping 通服务器
##3.执行挂载命令

NFS是什么?
NFS:Network File System(网络文件系统),NFS只是一种文件系统,本身并没有传输功能,是基于RPC协议实现的,为C/S架构。也就是说,NFS也只是文件系统而已,与jffs2,yaffs,ext4等是一类东西。但是NFS的特殊之处在于,它可以通过网络来挂载,而不用烧写到设备上。这就跟网吧里使用PXE启动来搭建无盘系统一样:每台电脑并没有安装硬盘,而是直接通过PXE启动服务器上的系统,看起来每台电脑都有硬盘,其实都是挂载服务器上的硬盘。

NFS怎么用?
前边已经介绍过,NFS是C/S架构,也就是说,使用NFS需要搭建服务器和客户端。客户端很简单,自带的uboot已经添加了对NFS客户端的支持,我们只需要管NFS服务器。这个服务器其实跟TFTP、Samba服务器、Ftp服务器也是一类的东西,直接在Ubuntu上使用命令安装即可,
先下载NFS服务器,演示如下:
sudo apt-get install nfs-kernel-server

很显然,我已经安装过了,在提供的Ubuntu9.10里也安装过了,继续往下走--------配置NFS服务器
sudo vi /etc/exports

默认状态下是没有配置的,可以参考给出的例子或者百度来决定配置信息
例如,可以配置成这样:

就是在文件里添加了

/work/nfs               *(rw,sync,no_root_squash)
/var/lib/tftpboot       *(rw,sync,no_root_squash)

然后保存,重启NFS服务器或者Ubuntu(如果不重启,配置不会生效),命令如下:

sudo /etc/init.d/nfs-kernel-server restart

简单解释各个参数的意义:
/work/nfs :允许客户端挂载的目录,可添加任意多个,如果不设置,服务器将不允许客户端挂载。

  •           :允许所有IP的主机挂载该目录
    

括号内的 :一些权限设置,比如是否能够读写(可百度,更详尽)
现在NFS服务器就可以用了。

  1. 查看开发板和Ubuntu的IP,设置开发板IP并ping通NFS服务器

  2. 把你想拷贝到开发板上的文件都复制到刚才设置的目录里,例如拷贝到 /work/nfs,然后在开发板上执行挂载命令
    mount -t nfs -o nolock,vers=2 10.0.0.147:/work/nfs /mnt

    解释一下:
    mount :挂载命令
    nfs :使用的协议
    nolock :不阻塞
    vers : 使用的NFS版本号
    IP : NFS服务器的IP(NFS服务器运行在哪个系统上,就是哪个系统的IP)
    /work/nfs: 要挂载的目录(Ubuntu的目录)
    /mnt : 要挂载到的目录(开发板上的目录,注意挂载成功后,/mnt下原有数据将会被隐藏,无法找到)

  3. 现在进入开发板上的/mnt目录,就可以看到Ubuntu上要传输的文件了

  4. 测试驱动,测试应用程序都可以在/mnt目录下进行,并且这个/mnt目录也不会占用开发板的Flash空间,很方便。

1 仅用flash上的根文件系统启动,手工MOUNT NFS 介绍完毕
强烈推荐这种方式,因为简单。随时想挂载就挂载,Ubuntu系统即使不开机(前提是ubuntu ip没变)也不影响开发板的启动。而 7.2 使用NFS作为根文件系统来启动 ,若Ubuntu未启动或者文件系统有问题,开发板根本无法开机,严重影响体验。

可能遇到的问题

典型的网络不通,检查彼此的IP,保证网络通畅。
很多初学者以为,在uboot状态下设置完IP能ping通Ubuntu那么开发板进入Linux后也一定能ping通Ubuntu,这是不对的。两种状态下的IP互不影响,也就是说uboot的IP不会传递给Linux,如果需要使用网络都需要分别设置IP。


解决方法:

①检查要挂载的目录/work/test是否在/etc/exports中声明过,如果没有,是没有挂载权限的,就参考前边的例子添加
在Ubuntu上执行命令 showmount -e 即可查看已经声明过的可被挂载的目录

②检查NFS服务器是否在运行
在Ubuntu上执行命令 sudo /etc/init.d/nfs-kernel-server status 即可查看nfsd是否正在运行,如果没有运行就参考前面的命令使其运行

#使用NFS作为根文件系统来启动
如果你仅仅是想要让开发板跟Ubuntu共享文件,那么强烈建议你用前面所提供的方式,因为 2 使用NFS作为根文件系统来启动 比较麻烦,这种启动方式主要用在制作文件系统上。下面详细说明!

视频一开始就教大家怎么重烧整个系统,怎么编译uboot,怎么编译内核都讲了,就是没有讲怎么制作文件系统。制作文件系统属于进阶内容,被放到了第11节。但是视频中又提前的介绍了NFS启动,这就导致很多紧跟视频操作不敢有丝毫遗漏的同学陷入深深的苦恼当中,无法在自己的开发板上复现视频中的现象是不可容忍的,有些同学甚至因此放弃了嵌入式的学习,这对一个过来人来说感觉是相当可惜的。现在我就慢慢引入为什么需要NFS启动吧。

大家都知道,开发板要想运行应用程序,文件系统是必不可少的,在光盘里有提供文件系统

参考视频的烧写方法,很容易能够烧写成功。但是这个文件系统是怎么制作出来的?只能看第11节的视频了,会发现步骤非常多。为了避免出错,需要时时看制作的效果。如果每做一步都用mkyaffs2image制作一个文件系统fs.yaffs2烧写到开发板上显然效率太低,此时NFS启动的优势就很明显了-----可以通过NFS启动的方式来实时看效果。

使用NFS启动的前提条件
编译内核和制作文件系统所用的交叉编译器必须相同(如果你用2.6.22.6的内核去挂载毕业班、第三期视频的NFS文件系统,肯定无法挂载)
步骤:

  1. 将制作的文件系统放到/work/nfs/jz2440目录下

  2. 参考上一个帖子的方式,添加路径 /work/nfs/jz2440 到文件 /etc/exports 中,以保证开发板有挂载这个目录的权限

  3. 重启nfs服务器

  4. 再次确认刚才设置的目录是否生效

  5. 查看Ubuntu的IP和开发板的IP,等会设置uboot启动参数时会用到

  6. 设置uboot启动参数
    set bootargs noinitrd root=/dev/nfs nfsroot=10.0.0.147:/work/nfs/jz2440 ip=10.0.0.10:10.0.0.147:10.0.0.1:255.255.255.0::eth0:off init=/linuxrc console=ttySAC0
    save

常见问题

  1. 如果你的文件系统制作的没有问题,那么重启开发板后应当能够进入Linux系统。如果挂载失败,就用光盘里提供的文件系统试试

    注意:光盘提供的文件系统中etc/init.d/rcS文件中已经默认添加了设置开发板IP的命令,如果你不需要这个IP或者跟你的网段不同,可以修改以符合自己的需要。光盘里提供的文件系统都是用arm-linux-gcc(3.4.5版本制作的),因此你必须使用2.6.22.6的内核来启动,否则无法挂载文件系统。

  2. 使用NFS启动你会发现一个问题,如果开发板跟Ubuntu之间的网络不通,那么你的开发板就启动不了。想想也很正常,客户端跟服务器网络不通是无法登陆的。如果你制作的文件系统经过测试没有任何问题,那就可以制作成yaffs2文件系统烧写到开发板上,不用每次都得打开Ubuntu,插上网线,再启动开发板了。
    在第一期视频第0课第7节03:40处有演示,

其实就是将NFS文件系统使用mkyaffs2image工具制作生成yaffs2格式的文件系统。至此,NFS全部挂载方式分析完毕。

NFS挂载的2种方式相关推荐

  1. 挂载的三种方式之自动挂载(autofs)

    Linux中文件挂载有三种方法: ①手动挂载 mount 设备名 挂载点目录 ②开机自动挂载 vim /etc/fstab ③ Autofs 自动挂载 前两种挂载方式不做细谈,今天主要谈谈autofs ...

  2. linux 识别 ntfs分区,Linux识别ntfs及分区挂载的四种方式

    NTFS-3G是一个开源软件,支持在Linux操作系统下读写NTFS格式的分区.它能快速且安全的操作Windows XP,Windows Server 2003, Windows 2000以及Wind ...

  3. Docker 实现挂载的三种方式

    最近学习了docker,做一些笔记来巩固知识,也供他人参考 文章目录 一 通过docker run命令 二 通过dockerfile创建挂载点 三 容器共享卷(挂载点) 四 最佳实践:数据容器 五 总 ...

  4. 云服务器下,与嵌入式板子传递文件的几种方式 |FTP SFTP SCP TFTP NFS | 以及NFS 挂载失败常见问题

    云服务器下,与嵌入式板子传递文件的几种方式 一.ftp.sftp.scp 1.ftp 2.sftp 3.scp 二.tftp 1.下载tftp 2.创建tftp服务器的文件目录 3.修改配置文件 /e ...

  5. 文件共享同步5种方式:NFS、NAS、rsync、scp、ftp

    谈到文件同步,我们最直接的同步方式是采用rsync的同步软件,rsync同步可以保持server和client的强一致(server中的增删改都会同步client),但在实际场景中rsync可能并不能 ...

  6. linux启动时挂载rootfs的几种方式 .

    转载链接:http://blog.csdn.net/zuokong/article/details/9022707 根文件系统(在样例错误消息中名为 rootfs)是 Linux 的最基本的组件.根文 ...

  7. 文件共享同步5种方式-NFS、NAS、rsync、scp、ftp

    谈到文件同步,我们最直接的同步方式是采用rsync的同步软件,rsync同步可以保持server和client的强一致(server中的增删改都会同步client),但在实际场景中rsync可能并不能 ...

  8. Docker的常用管理命令Docker将数据挂载到容器的三种方式

    文章目录 镜像管理命令 容器管理常用命令 docker run常用参数 Docker run的其他参数 docker 创建容器命令 容器资源限制 docker管理容器常用命令 docker将数据挂载到 ...

  9. NFS挂载文件系统出现nfsnobody解决方式

    最近在开发时使用nfs远程挂载目录时,出现了图片上传失败,经过一系列排查. 查看了上传目录,所属用户却是nfsnobody,如下所示: $ ll -d /web/img drwxr-xr-x 7 nf ...

最新文章

  1. KernelPCA进行非线性数据的映射和分类
  2. linux系统下安装qgis,深度操作系统 deepin 15.11安装 QGIS 3.4
  3. repeater导出excel html,Repeater显示数据,并且导出到excel
  4. 通过8个技巧让你成为一个超强的Linux终端用户
  5. 如何理解傅立叶级数、傅立叶变换公式?
  6. Springboot集成mybatis通用Mapper与分页插件PageHelper
  7. 避免uicollection view被错误的移动
  8. 空值的日期类型和update 中的null
  9. curl post json_Go Web编程--解析JSON请求和生成JSON响应
  10. springboot 连接sftp服务器
  11. MPB:青岛大学苏晓泉组-使用Meta-Apo对16S扩增子的微生物组功能信息进行校正
  12. cap理论具体含义_什么是CAP定理?
  13. CCF中A类和B类会议投稿时间和投稿页面整理(人工智能、网络安全、数据库相关)
  14. 一次RAC主机资源使用异常导致的节点重启
  15. 关于TDA1557Q
  16. 中国科学院大学计算机非全日制,中国科学院大学能考非全日制研究生?
  17. FairyGUI基础学习笔记
  18. C语言rot90的头文件,python – np.rot90()破坏了opencv图像
  19. 基于p2p点播html5源码,毕业论文-基于HTML5的P2P流媒体传输系统的设计与实现.docx...
  20. grep(模式匹配器)详解

热门文章

  1. linux下文件时间戳修改
  2. python 读xlsx文件数据_python 怎么读取xlsx文件
  3. R语言读取xlsx文件
  4. 一个细菌基因组完整分析脚本
  5. 数据分析/论文作者统计
  6. 2021年起重机械指挥考试内容及起重机械指挥模拟考试系统
  7. FFmpeg的H.264解码器源代码简单分析:宏块解码(Decode)部分-帧内宏块(Intra)...
  8. 。颜色 网页色彩转载 白底
  9. 服务器虚拟化分类,虚拟化技术分四大类 你都学会了吗?
  10. Homestead 发布