配置nfs服务器

配置nfs服务器

 
在ubuntu下安装、配置nfs服务的步骤如下:
1、安装nfs
Ubuntu上默认是没有安装nfs服务器的,因此我们首先安装nfs服务器端:
$sudo apt-get install nfs-kernel-server
在一些文档中,提出还需要使用apt-get来手动安装nfs的客户端nfs-common,以及端口映射器portmap,但其实这是没有必要的,因为在安装nfs-kernel-server时,apt会自动为我们把它们安装好。

2、配置/etc/exports
nfs允许挂载的目录及权限在文件/etc/exports中进行了定义。
例如,我们要将根目录下的rootfs目录共享出来,那么我们需要在/etc/exports文件末尾添加如下一行:

/rootfs  *(rw,sync,no_root_squash)
其中: /rootfs是要共享的目录,

            *代表允许所有的网络段访问,

            rw是可读写权限,sync是资料同步写入内存和硬盘,

no_root_squash是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、重启服务
$sudo /etc/init.d/portmap restart
$sudo /etc/init.d/nfs-kernel-server restart

4、测试nfs
此时可以运行以下命令来显示一下共享出来的目录:
$showmount -e
或者可以使用以下命令把它挂载在本地磁盘上,例如将/rootfs挂载到/mnt下:
$sudo mount -t nfs localhost:/rootfs /mnt

可以运行df命令查看是否挂载成功。查看后可以使用以下命令卸载:
$ sudo umount /mnt

------------------------------------------------

关于NFS配置错误

 

ubuntu测试本机nfs出错:mount.nfs:access denied by server while mounting...

相信出现这种错误的应该有一些人吧,没关系,一会就帮你搞定。
首先运行:sudo vim /etc/exports
在其文本后添加
/home/work 192.168.1.*(rw,sync,no_root_squash)
然后保存退出。

注意,上面的主机IP可能不能使用*来通配,否则在客户机上会出现访问拒绝,但是如果我们要设置局域网访问呢?怎么办,使用子网掩码例如:10.1.60.0/255.255.254.0即可让10.1.60.*和10.1.61.*都可以访问,还可以使用10.1.60/23这种方式类确定子网。

/home/work就表示共享目录,当然,你可以随便换成自己喜欢的目录,192.168.1.*,前面三位是你主机的ip地址(怎么获得本机的ip地址?ifconfig命令就可以了)
rw:读/写权限,只读权限的参数为ro;
sync:数据同步写入内存和硬盘,也可以使用async,此时数据会先暂存于内存中,而不立即写入硬盘。
no_root_squash:NFS 服务器共享目录用户的属性,如果用户是 root,那么对于这个共享目录来说就具有 root 的权限。

下面浅蓝色的文字,可略过去!
起用保护机制
上面设置了只要在192.168.1.*这个网段的所有IP地址用户都可以访问共享目录,但我只想让一个IP地址访问,比如192.168.1.101(把刚才192.168.1.*直接换成192.168.1.101不行么?应该可以吧,没试过),那么就可以这样设置了。
可以通过设定/etc/hosts.deny和/etc/hosts.allow文件来限制网络服务的存取权限。
***/etc/hosts.deny***
portmap:ALL
lockd:ALL
mountd:ALL
rquotad:ALL
statd:ALL
***/etc/hosts.allow***
portmap:192.168.1.101
lockd:192.168.1.101
mountd:192.168.1.101
rquotad:192.168.1.101
statd:192.168.1.101
同时使用这两个文件就会使得只有ip为192.168.1.101的机器使用NFS服务。你的target
board的ip地址设定为192.168.1.101,这样就可以了。
浅蓝色文字可略过。

接着执行如下命令:
启动端口映射: #sudo
/etc/rc.d/init.d/portmap start(如果说找不到,就执行 #sudo /etc/init.d/portmap start)
如果这一步不成功,最后也连接不上了。
启动NFS 服务: #sudo /etc/rc.d/init.d/nfs start(又找不到,执行 #sudo
/etc/init.d/nfs start或#sudo /etc/init.d/nfs-kernel-server start)
这两项执行成功
的话,就会显示[ok]
最后执行:#sudo mount –t nfs 192.168.1.101:/home/work /mnt
这里面的192.168.1.101是你自己主机的ip地址,也可以用127.0.0.1来代替自己的主机ip地址,同样可以连接上。/home/work就是刚才在etc/exports里添加的路径。
如果在这一步又出错了,呵呵,重新#sudo vim /etc/exports,将“ 192.168.1.*”换成“*”,就这一个星星哦!
执行:# ls /mnt

恭喜你,mnt下是不是有了/home/work里的内容了。

卸载:#sudo umount /mnt/

如果上面操作做好了,还是不行,我觉得你应该重启一下机子试一下了!
更详细请点击:linux.chinaunix.net/bbs/thread-985579-1-1.html

提示:挂载根文件时,提示“Warning: unable to open an initial console. ”启动信息问题的解决,以NFS为例。

清单51 问题现象


VFS: Mounted root (nfs filesystem).

Freeing init memory: 144K

Warning: unable to open an initial console.<启动停到此处>


根据提示信息定位错误

查找错误原因: 根据错误提示信息:”Warning: unable to open an initial
console.”查看内核源代码。可定位错误提示在内核文件linux-2.6.26.2/init/main.c文件中。

清单52 分析main.c的调用关系


asmlinkage void __init start_kernel(void)

{

rest_init();

}

static void noinline __init_refok rest_init(void)

__releases(kernel_lock)

{

kernel_thread(kernel_init, NULL, CLONE_FS | CLONE_SIGHAND);

}

static int __init kernel_init(void * unused)

{

init_post();

return 0;

}

static int noinline init_post(void)

{

if (sys_open((const char __user *) "/dev/console", O_RDWR,
0) < 0)

printk(KERN_WARNING "Warning: unable to open an initial
console.
\n");

run_init_process("/sbin/init");

}通过分析知道内核启动时需要成功打开/dev/console设备,否则给出"Warning: unable to open an
initial console.
"的错误提示。

//为目标机配置console设备文件节点

进入你的nfs文件系统的/dev/目录

sudo mknod console c 5 1

创建console文件,再重启即可。

如果还不可以可以试下以下操作:

内核启动显示:

Warning: unable to open an initial console.
Failed to execute /linuxrc.  Attempting defaults...
Kernel panic - not syncing: No init found.  Try passing init= option to kernel.

解决:

创建rootfs过程中,在/dev目录下手动创建如下节点:

sudo mknod -m 660 null c 1 3

sudo mknod -m 660 console c 5 1


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值