文章目录
- 1 本篇文章解决的问题
- 2 问题解决原理
- 3 问题环境
- 4 开启 ubuntu-20.04 的 nfs2
- 4.1 确认 nfs2 是否已经开启
- 4.2 开启 nfs2
- 5 卸载 iptables
- 5.1 卸载 iptables
- 5.2 禁用 ufw
- 5.3 尝试重新下载
- 6 原理分析
- 6.1 nfs2 开启部分
- 6.2 卸载 iptables 部分
- 7 后记
- 7.1 拓扑结构一
- 7.2 拓扑结构二
1 本篇文章解决的问题
- 正点原子的嵌入式 Linux 教程中,通过 nfs 下载出现 T T T T [Retry count exceeded: starting again]
- 开启并确认虚拟机服务器已经支持 nfs2,但是这个问题仍然没有得到解决
2 问题解决原理
- ubuntu 20.04 默认不支持 nfs2,需要手动开启。但是根据网上的其他文章进行修改,无果。比如在
/etc
文件夹下面根本找不到 nfs 的配置文件nfs.conf
- 虚拟机开启 nfs2 后,通过 nfs 下载仍然出现 T T T T 的重试(nfs 80800000 192.168.31.128:/home/witheart/linux/nfs/zImage
),这是 ubuntu 中的 iptables 导致的
3 问题环境
- 虚拟机版本为 ubuntu-20.04
- 开发板为正点原子 I.MX6ULL Linux 阿尔法开发板-V2.4
- 虚拟机可以 ping 通开发板
- 关闭了火绒,系统防火墙
4 开启 ubuntu-20.04 的 nfs2
注意,此处开启 nfs2 的步骤不同于其他教程,主要是针对 ubuntu-20.04 没有 /etc/nfs.conf
这个文件,其他教程需要修改这个文件但是在 ubuntu-20.04 下安装 nfs 后并不能找到这个文件。
- 如下面这两个教程,都是需要修改
nfs.conf
文件的,但是我在这个环境下并没有找到这个文件:
https://blog.csdn.net/m0_58756221/article/details/136066519
https://blog.csdn.net/weixin_56646002/article/details/127388021
4.1 确认 nfs2 是否已经开启
- 查看 nfs 的版本
sudo cat /proc/fs/nfsd/versions
+2 就代表已经开启 nfs2 服务,则第 4 节可跳过,如果是 -2 就往下看,开启 nfs2
4.2 开启 nfs2
参考文章:
https://blog.csdn.net/Qiuoooooo/article/details/112601940
- 进入
/etc/default/nfs-kernel-server
这个文件
sudo vim /etc/default/nfs-kernel-server
- 添加这一行,保存退出:
- 更新 Linux 系统上的 NFS(网络文件系统)导出列表:
sudo exportfs -ar
此命令没有其他输出。
- 查看 Linux 系统中与 NFS 相关的网络连接信息
netstat -a | grep "nfs"
有udp最重要
- 再次查看 Linux 系统上 NFS 服务器支持的协议版本
sudo cat /proc/fs/nfsd/versions
有 +2
说明已经支持 nfs2 了
5 卸载 iptables
开启 nfs2 后,可以在开发板 u-boot 上重新尝试用 nfs 下载虚拟机上的文件,如果成功了,那么就结束了。如果不幸你和笔者一样发现开启 nfs2 后依旧出现 T T T T 的超时,那么很有可能是 iptables
搞的鬼!
5.1 卸载 iptables
sudo apt-get remove iptables
sudo apt-get purge iptables
输出:
5.2 禁用 ufw
-
禁用
ufw
:使用以下命令禁用
ufw
,这将关闭所有通过ufw
配置的防火墙规则:sudo ufw disable
-
停止
ufw
服务:sudo systemctl stop ufw
-
禁用
ufw
服务开机启动:sudo systemctl disable ufw
5.3 尝试重新下载
- 在开发板 u-boot 上重新尝试用 nfs 下载虚拟机上的文件,如果成功了,那么就结束了。
- 如果还是不行,尝试关闭火绒后重新操作。
6 原理分析
6.1 nfs2 开启部分
- 为什么找不到
nfs.conf
,笔者刚开始以为是 nfs 安装问题,反复重试了几次,都找不到nfs.conf
,后面从下面这个网站发现在 ubuntu-20.04 上,安装 nfs 后,可能根本就没有/etc/nfs.conf
这个文件。
https://bugs.launchpad.net/ubuntu/+source/nfs-utils/+bug/1973101
6.2 卸载 iptables 部分
ufw
(Uncomplicated Firewall)是 Ubuntu 和其他基于 Debian 的发行版中常用的防火墙工具。iptables
是 Linux 系统中的一个命令行工具,用于配置、维护和检查 IP 数据包过滤规则。它是 Linux 内核中的防火墙模块netfilter
的用户空间接口,允许管理员定义规则以控制流入和流出的网络流量。- 这两个模块都会导致虚拟机能 ping 通开发板,但是 nfs 无法下载,不断重试,出现 T T T T …。
- 参考教程
http://47.111.11.73/thread-305543-1-1.html
7 后记
在两种网络拓扑结构上都尝试了一下,问题都解决了。
7.1 拓扑结构一
参考正点原子这个视频设置的:
https://www.yuanzige.com/course/detail/50096?section_id=87473
- 开发板接电脑网口
- 电脑通过wifi上网
- 虚拟机设置一桥接网卡专门用于与连接在电脑网口上的开发板通信
- 虚拟机设置另一 NAT 网卡用于访问外网
7.2 拓扑结构二
- 电脑、开发板、虚拟机都通过网线连接路由器