linux网络盘 nobody,nfs只能挂载为nobody的解决方法

不得不承认centos6较centos5发生了很大的变化,在新部署的centos 6.4上又遇到nfs挂载的问题。问题现象是,在配置完nfs后,无论配置里指定的是何用户,挂载成功后显示的只能是nobody用户,本想通过修改/etc/passwd和/etc/group对应的uid和gid号解决,发现重新挂载后,用户仍然是nobody 。

造成该问题的原因是,在centos 6版本中默认使用的nfs-v4版本,其提供了称为rpc.idmapd 的守护进程,并使用 /etc/idmapd.conf 的配置文件。当请求加载nfsv4 时,该守护进程将处理 UID 和 GID 映射。默认使用nis,没有nis它会自动映射成nobody用户。

既然找到了原因,找解决方法也就不难了,大致找了下网上的解决方法,分如下两种。

方法一:mount中指定参数法

在mount挂载的时候指定使用v3版本去挂载,如下:mount -t nfs -o vers=3 ip:/data1 /data1

显然不推荐该方法,既然有了V4版本,其肯定较V3版本做了很多优化,如果再用V3,显然跟不上时代的步伐 。

方法二:修改/etc/idmapd.conf文件

修改前,先看下为什么会mount成nobody,在/etc/idmapd.conf文件中,mapping配置下有如下两句 。[Mapping]

Nobody-User = nobody

Nobody-Group = nobody

有人肯定说,直接修改这两句,变成想要的用户和组不就行了 ? 当然没这么简单,这里改了后,会发现mount的目录只有读的权限,没有写的权限 。想在彻底的解决该文件,只需要客户端和服务端各改一行就行了。修改方法为,取消/etc/idmapd.conf中如下行的注释,改为你所使用的根域名:#Domain = local.domain.edu

如:都改为:Domain = 361way.com

更改完成后,重启idmapd服务:service rpcidmapd restart

至此,问题解决。记得是客户端和服务端都要修改才行,只改一处,问题仍然无法解决 。另外在umount的过程中,还可能遇到无法umount的问题:root@test:/# umount /data1/nfs/

umount.nfs: /data1/nfs: device is busy

umount.nfs: /data1/nfs: device is busy

遇到该问题时只需要使用fuser命令就可以解决:root@test:/# fuser -km /data1/nfs/

root@test:/# fuser -f /data1/nfs/

执行完上面的操作后,再去umount就可以了。fuser上面用到的几个参数的意义如下:-f silently ignored (for POSIX compatibility)

-i ask before killing (ignored without -k)

-k kill processes accessing the named file

-m show all processes using the named filesystems

要实现将一块硬挂载到多个Linux主机上共享,可以使用NFS协议。下面是具体的步骤: 1. 在拥有硬的主机上安装NFS服务器软件包。在Debian/Ubuntu上,可以使用以下命令安装: ``` sudo apt-get update sudo apt-get install nfs-kernel-server ``` 2. 在NFS服务器上创建一个共享目录,并修改该目录的权限和拥有者。例如: ``` sudo mkdir /nfs/share sudo chown nobody:nogroup /nfs/share sudo chmod 777 /nfs/share ``` 3. 编辑NFS服务器的导出文件/etc/exports,添加对共享目录的导出配置。例如: ``` /nfs/share 192.168.1.0/24(rw,sync,no_root_squash) ``` 其中,/nfs/share是共享目录的路径,192.168.1.0/24是允许访问该共享的IP地址段,rw表示可读写,sync表示同步写入,no_root_squash表示不对root用户进行权限限制。 4. 重新加载NFS服务器配置: ``` sudo exportfs -a sudo systemctl restart nfs-kernel-server ``` 5. 在其他主机上安装NFS客户端软件包。在Debian/Ubuntu上,可以使用以下命令安装: ``` sudo apt-get update sudo apt-get install nfs-common ``` 6. 在NFS客户端上创建一个本地目录,用于挂载NFS共享。例如: ``` sudo mkdir /mnt/nfs_share ``` 7. 在NFS客户端上挂载NFS共享: ``` sudo mount -t nfs4 192.168.1.100:/nfs/share /mnt/nfs_share ``` 其中,192.168.1.100是NFS服务器的IP地址,/nfs/share是共享目录的路径,/mnt/nfs_share是本地挂载点的路径。 8. 确认NFS共享已经成功挂载: ``` df -hT ``` 可以看到,共享目录已经挂载到了本地的/mnt/nfs_share目录下,可以在该目录下读写和访问共享文件了。 重复以上步骤,可以将该硬挂载到多个Linux主机上共享。需要注意的是,在多个主机上同时挂载同一块硬时,需要注意文件锁定等并发访问的问题,以避免数据损坏或文件冲突。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值