安装与配置 nfs服务
1、安装 nfs
Ubuntu默认没有安装 nfs服务器,安装 nfs服务器端
$sudo apt-get install nfs-kernel-server
2、配置/etc/exports
nfs允许挂载的目录及权限在文件/etc/exports中进行了定义
例如:共享目录为/rootfs,需要在/etc/exports文件末尾添加如下一行:
/rootfs *(rw,sync,no_root_squash)
其中:
/rootfs是要共享的目录
*代表允许所有的网络段访问
rw是可读写权限
sync是资料同步写入内存和硬盘
no_root_squash是Ubuntu nfs客户端分享目录使用者的权限,如果客户端使用的是root用户,那么对于该共享目录而言,该客户端就具有root权限
其它 nfs常用的参数有:
ro 只读访问
rw 读写访问sync 所有数据在请求时写入共享
async nfs在写入数据前可以响应请求
secure nfs通过1024以下的安全TCP/IP端口发送
insecure nfs通过1024以上的端口发送
wdelay 如果多个用户要写入nfs目录,则归组写入(默认)
no_wdelay 如果多个用户要写入nfs目录,则立即写入,当使用async时,无需此设置。
hide 在nfs共享目录中不共享其子目录
no_hide 共享nfs目录的子目录
subtree_check 如果共享/usr/bin之类的子目录时,强制nfs检查父目录的权限(默认)
no_subtree_check 和上面相对,不检查父目录权限
all_squash 共享文件的UID和GID映射匿名用户anonymous,适合公用目录。
no_all_squash 保留共享文件的UID和GID(默认)
root_squash root用户的所有请求映射成如anonymous用户一样的权限(默认)
no_root_squas root用户具有根目录的完全管理访问权限
anonuid=xxx 指定nfs服务器/etc/passwd文件中匿名用户的UID
anongid=xxx 指定nfs服务器/etc/passwd文件中匿名用户的GID
3、systemctl 操作nfs服务
$sudo systemctl start nfs-server.service 开启服务
$sudo systemctl status nfs-server.service 查看状态
$sudo systemctl enable nfs-server.service 设置开机自启动
4、测试 nfs
运行以下命令来显示共享出来的目录:
$showmount -e
或者把它挂载到本地磁盘上,例如将/rootfs挂载到/mnt下:
$ sudo mount -t nfs localhost:/rootfs /mnt
可以运行df命令查看是否挂载成功
$ sudo df
查看后可以使用以下命令卸载:
$ sudo umount /mnt
5、在开发板端mount服务器的文件系统
主 机:192.168.1.100
开发板:192.168.1.88
先在开发板端ping下主机,看是否网络相通,然后运行命令:
mount -t nfs -o nolock 192.168.1.100:/rootfs /mnt
如果服务器端的防火墙有开着的话,将会提示错误,如:mount: mount to NFS server ‘192.168.1.100’ failed: System Error: No route to host.
只需关闭防火墙即可:service iptables stop 或systemctl stop firewalld.service
常用命令:
1、查路由表 route -n
2、显示共享目录 exportfs -rv
3、防火墙和 selinux 状态 getenforce或systemctl status firewalld.service
6、网络加载文件系统
1、内核配置 nfs 文件系统
a、配置:IP_PNP
Networking support --->
Networking options --->
b、配置:ROOT_NFS
File systems --->
Networking File systems --->
2、内核启动参数
g console=ttyS0,115200 root=/dev/nfs rw nolock nfsroot=10.50.122.10:/nfsboot/rootfs-ls23,v3 ip=10.50.122.100:::::eth0:off