位置: IT常识 - 正文

Linux下NFS网络文件系统的基本使用教程(linux7 nfs)

编辑:rootadmin
这篇文章主要介绍了Linux下NFS网络文件系统的基本使用教程,配置方面写得非常详细,同时给出了一些常见错误的解决方法以及需要注意的地方,非常推荐,需要的朋友可以参考下... 16-03-18

推荐整理分享Linux下NFS网络文件系统的基本使用教程(linux7 nfs),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:linux的nfs如何使用,linux服务器nfs配置总结,linux nf,linux服务器nfs配置总结,linux nf,linux nf,linux nfs配置文件,linux中nfs的搭建,内容如对您有帮助,希望把文章链接给更多的朋友!

0.什么是NFS(Network FileSystem) NFS 就是 Network FileSystem 的缩写,最早之前是由 Sun 所发展出来的。他最大的功能就是可以透过网络,让不同的机器、不同的操作系统、可以彼此分享个别的档案 ( share file ),所以,也可以简单的将他看做是一个 file server !这个 NFS Server 可以让你的 PC 来将网络远程的 NFS 主机分享的目录,挂载到本地端的机器当中,所以,在本地端的机器看起来,那个远程主机的目录就好象是自己的 partition 一样!虽然 NFS 有属于自己的协议与使用的 port number ,但是在资料传送或者其它相关讯息传递的时候, NFS 使用的则是一个称为远程过程调用( Remote Procedure Call, RPC )的协议来协助 NFS 本身的运作!

1. NFS至少有两个主要部分:一台服务器和一台(或者更多)客户机。客户机远程访问存放在服务器上的数据。为了正常工作,一些进程需要被配置并运行。NFS服务器的安装:检查linux系统中是否安装了nfs-utils和portmap两个软件包 (RHEL4系统默认已经安装了这两个软件包)命令

代码如下:#rpm –q nfs-utils portmap

查看NFS服务器是否启动:命令

代码如下:#service nfs starus#service portmap status

如果服务器没有启动,则开启服务(默认服务下nfs没有完全开启)命令

代码如下:#service nfs start#service portmap start

2.RPC 当我们在使用某些服务来进行远程联机的时候,有些信息,例如主机的IP、服务的 port number、与对应到的服务之 PID 等等,都需要管理与对应!这些管理 port 的对应与服务相关性的工作,就是这个 Remote Procedure Call, RPC 的任务了。NFS 本身的服务并没有提供资料传递的协议,但是 NFS 却能让我们进行档案的分享,这其中的原因,就是 NFS 使用到一些其它相关的传输协议!而这些传输的协议,就是使用到这个所谓的 RPC 的功能啰!这也就是说, NFS 本身就是使用 RPC 的一个 program 就是了!说的更白话一点, NFS 也可以视作是一个 RPC server 啦!同时要注意到的是,在某些状况中,不但跑 NFS 的 Server 需要激活 RPC 的服务,连带的,要挂载 NFS partition 的 Client 机器,也需要同步激活 RPC 才行!这样 Server 端与 Client 端才能藉由 RPC 的协议来进行 program port 的对应喔!NFS 主要在管理分享出来的目录,而至于资料的传递,就直接将他丢给 RPC 的协议来运作就是了!

3.NFS 激活的 RPC daemons rpc.nfsd:这个 daemon 主要的功能就是在管理 Client 是否能够登入主机的权限啦,其中还包含这个登入者的 ID 的判别 rpc.mountd:这个 daemon 主要的功能,则是在管理 NFS 的档案系统!当 Client 端顺利的通过 rpc.nfsd 而登入主机之后,在他可以使用 NFS server 提供的档案之前,还会经过档案使用权限 ( 就是那个 -rwxrwxrwx 与 owner, group 那几个权限啦 ) 的认证程序!他会去读 NFS 的设定档 /etc/exports 来比对 Client 的权限,当通过这一关之后, Client 就可以取得使用 NFS 档案的权限啦!(注:这个也是我们用来管理 NFS 分享之目录的使用权限与安全设定的地方哩)

4.NFS需要有两个套件才行,分别是:nfs-utils就是提供 rpc.nfsd 及 rpc.mountd 这两个 NFS daemons 与其它相关 documents 与说明文件、执行档等的套件!这个就是 NFS 的主要套件portmap 就如同刚刚提的到,我们的 NFS 其实可以被视为一个 RPC server program,而要激活任何一个 RPC server program 之前,我们都需要做好 port 的对应 ( mapping ) 的工作才行,这个工作其实就是『 portmap 』这个服务所负责的!也就是说,在激活任何一个 RPC server 之前,我们都需要激活 portmap 才行呢!那么这个 portmap 到底在干嘛呢?就如同这个服务的名称,哈哈!就是作 port 的 mapping 啊!举个例子来说:当 Client 端尝试来使用 RPC server 所提供的服务时,由于 Client 需要取得一个可以连接的 port 才能够使用 RPC server 所提供的服务,因此, Client 首先就会去跟 portmap 讲『喂!可不可以通知一下,给我个 port number ,好让我可以跟 RPC 联络吧!』这个时候 portmap 就自动的将自己管理的 port mapping 告知 Client ,好让他可以连接上来 server 呢!所以啰:『激活 NFS 之前,请先激活 portmap !』

5.NFS server端的设定:a)/etc/exports分享的目录 主机名称1或IP1(参数1,参数2) 主机名称2或IP2(参数3,参数4)b).参数rw: 可擦写的权限ro: 只读的权限no_root_squash: 登入 NFS 主机使用分享目录的使用者,如果是 root 的话,那么对于这个分享的目录来说,他就具有 root 的权限!这个项目『极不安全』,不建议使用!root_squash: 在登入 NFS 主机使用分享之目录的使用者如果是 root 时,那么这个使用者的权限将被压缩成为匿名使用者,通常他的 UID 与 GID 都会变成 nobody 那个身份;all_squash: 不论登入 NFS 的使用者身份为何,他的身份都会被压缩成为匿名使用者,通常也就是 nobody 啦!anonuid: 前面关于 *_squash 提到的匿名使用者的 UID 设定值,通常为 nobody,但是你可以自行设定这个 UID 的值!当然,这个 UID 必需要存在于你的 /etc/passwd 当中!anongid: 同 anonuid ,但是变成 group ID 就是了sync: 资料同步写入到内存与硬盘当中async: 资料会先暂存于内存当中,而非直接写入硬盘

6.设置的实例:a)/tmp *(rw,no_root_squash) //*号表示所有的IP都可以访问b)/tmp *(rw) /home/public 192.168.0.*(rw) *(ro) //下面两行作用一样 /home/public 192.168.0.0/24(rw) *(ro)c)/home/test 192.168.0.100(rw) //只对某部机器设置权限d)/home/linux *.linux.org(rw,all_squash,anonuid=40,anongid=40) //当*.linux.org登陆此NFS主机,并且在/home/linux下面写入档案时,该档案的所有人与所有组,就会变成/etc/passwd里面对应的UID为40的那个身份的使用者了.

7.权限问题假设/etc/exports里面的内容为

代码如下: #vi /etc/exports /tmp *(rw,no_root_squash) /home/public 192.168.0.*(rw) *(ro) /home/test 192.168.0.100(rw) /home/linux *.linux.org(rw,all_squash,anonuid=40,anongid=40)

假设我们在192.168.0.100这个client端登陆此NFS主机(192.168.0.2),那么情况一:在192.168.0.100的帐号为test这个身份,同时,NFS主机上也有test这个帐号 a).由于NFS主机的/tmp权限为-rwxrwxrwt,所以我(test在192.168.0.100上)在/tmp下面具有存取的权限,并且写入档案的所有人为test. b).在/home/public中,由于我有读写的权限,如果NFS主机在/home/public这个目录的权限对于test开放写入的话,那么就可以读写,并且写入档案的所有人是test。如果NFS主机的/home/public对于test这个使用者并没有开放写入权限时,那就无法写入,虽然/etc/exports里面是rw,也不起作用. c).在/home/test中,权限与/home/public有相同的状态,需要NFS主机的/home/test对于test有开放的权限. d).在/home/linux当中,不论是何种的user,身份都会被变成UID=40的这个帐号情况二:如果我们在192.168.0.100的身份为test2,但是NFS主机却没有test2这个帐号时 a).在/tmp下还是可以写入,但是写入的档案所有人变成nobody. b).在/home/public与/home/test里面是否可以写入,还需要看/home/public的权限而定,不过身份就被变成nobody了 c)/home/linux下的身份还是变成UID=40的帐号.情况三:在192.168.0.100的身份为root a).在/tmp里面可以写入,但是由于no_root_squash的参数,改变了预设的root_squash的设定值,所以在/tmp写入档案的所有人为root了. b).在/home/public底下的身份被压缩成了nobody,因为预设的属性都具有root_squash,所以档案所有人就变成了nobody. c)./home/test情况与/home/public相同. d)./home/linux中,root的身份也被压缩成UID=40的那个使用者了.

8.启动服务portmap,nfs

代码如下: #/etc/rc.d/init.d/portmap start

(or:

代码如下:#service portmap start

)

代码如下: #/etc/rc.d/init.d/nfs start Linux下NFS网络文件系统的基本使用教程(linux7 nfs)

(or:

代码如下:#service nfs start

)可以到/var/log/messages里面查看是否正确激活

9.exportfs的用法如果我们修改了/etc/exports后,并不需要重启nfs服务,只要用exportfs重新扫描一次/etc/exports,并且重新加载即可语法: exportfs [-aruv]-a: 全部挂载(或卸载) /etc/exports档案内的设定-r: 重新挂载/etc/exports里面的设定,也同步的更新/etc/exports和/var/lib/nfs/xtab里面的内容-u:卸载某一目录-v:在export的时候,将分享的目录显示到荧屏上.例子

代码如下: #exportfs -rv //重新export一次 #exportfs -au //全部卸载

10./var/lib/nfs/xtab里面可以查看每个目录的分享权限(但是我怎么也没有找到,靠,找到了,原来要有人mount上nfs后才会出现内容),如:/tmp node3(ro,sync,wdelay,hide,secure,root_squash,no_all_squash,subtree_check,secure_locks,mapping=identity,anonuid=-2,anongid=-2)为什么anonuid=-2呢?呵呵!其实它说的是将 65536-2 的值,也就是 65534 的那个 UID 啦!对照一下 /etc/passwd ,你就会发现,哇!原来那就是 nobody 的啦

11.showmount命令语法: showmount [-ae] hostname-a: 显示目前主机与client所连上来的使用目录的状态-e: 显示hostname的/etc/exports里面共享的目录

12.查看激活的portnumber

代码如下: #netstat -utln

nfs 自己所开启的 port ,就是那个 2049 的 port 啦!就是 NFS 主要产生的 port NFS server 在前面我们就提过了,他是 RPC server 的一种,而 NFS 由于提供了多个 program ( 例如 rpc.mountd, rpc.rquotad, rpc.nfsd... ) ,因此就需要激活多个 port 了!而且这些 port 是『随机产生的』,也就是那个 port number 不会是固定的啦!每次 restart nfs 都会得到不一样的 port number 呢!那么 Client 端怎么知道要连接上那个 port 来呼叫需要的 program 呢?呵呵!那就是 sunrpc ( port 111 ) 那个 portmap 服务所产生的 port number 的功用啦!Client 会先连接到 sunrpc 那个 port 去知道应该到那个 port 去呼叫所需要的程序!所以啰, rpc.xxxx 等之类的 daemon 自然就不需要有固定的 port number 啰!

NFS客户端的设定

代码如下: #mount -t nfs hostname(orIP):/directory /mountpoint

搞定,就这么简单为了担心会不小心将 NFS 端挂进来的具有 SUID 权限档案的程序执行,root可以将NFS 所分享的目录以较为安全的情况挂载进来,可以

代码如下:#mount -t nfs -o nosuid,ro hostname:/directory /mountponit

可能出问题的地方:1.权限的设定不符合2.忘记了激活portmap,此时会报错:mount: RPC: Port mapper failure-RPC: Unable to receive 或者mount: RPC: Program not registered那么,启动portmap,并且重新启动nfs

代码如下: #service portmap start #service nfs restart

3.被防火墙搞掉重新设置防火墙,包括iptables与TCP_Wrappers,因为激活了portmap,所以port 111必须提供出去.因此在iptables rules中,要增加:

代码如下: iptables -A INPUT -p TCP --dport 111 -j ACCEPT iptables -A INPUT -p UDP --dport 111 -j ACCEPT

如果还不行,那就是TCP_Wrappers的问题,检查/etc/hosts.deny,如果有一行是:

代码如下: ALL: ALL: deny

那就必须在/etc/hosts.allow中增加:

代码如下: portmap: ALL: allow

如果我们的NFS针对内部网络开发,对于外部网络只对学术网络开发(140.0.0.0/8),可以:

代码如下: iptables -A INPUT -i eth0 -p TCP -s 192.168.0.0/24 --dport 111 -j ACCEPT iptables -A INPUT -i eth0 -p UDP -s 192.168.0.0/24 --dport 111 -j ACCEPT iptables -A INPUT -i eth0 -p TCP -s 140.0.0.0/8 --dport 111 -j ACCEPT iptables -A INPUT -i eth0 -p UDP -s 140.0.0.0/8 --dport 111 -j ACCEPT

还可以使用TCP_Wrappers,在/etc/hosts.allow里面规定连上 NFS 主机的主机 IP 与名称,例如

代码如下: #vi /.etc/hosts.allow portmap: 192.168.0.0/255.255.255.0 :allow portmap: 140.113.23.23 :allow portmap: .sdu.edu.cn :allow

RPC Server的相关命令

代码如下: rpcinfo #rpcinfo -p hostname(orIP)

要注意的问题:需要注意的是,由于 NFS 使用的这个 RPC 在 client 端连上主机时,那么你的主机想要关机,那可就会成为『不可能的任务』!我还不知道正确的原因是什么,但是,如果你的 Server 上面还有 Client 在联机,那么你要关机,可能得要等到数个钟头才能够正常的关机成功!嗄!真的假的!不相信吗?不然您自个儿试试看! ^_^!所以啰,建议您的 NFS Server 想要关机之前,能更先『关掉 portmap 与 nfs 』这两个东西!如果无法正确的将这两个 daemons 关掉,那么先以 netstat -utlp 找出 PID ,然后以 kill 将他关掉先!这样才有办法正常的关机成功喔!这个请特别特别的注意呢!

在TurboLinux8.0 for AMD64 (kernel 2.4.21-4smp),mount NFS时候报错为: portmap: server localhost not responding, timed out 解决办法:

代码如下: mount -t nfs -o nolock node1:/public /public

即增加-o nolock参数,原因:Unfsd doesn't support NLM locking, and it's causing the lockd daemon to be started (which again requires the portmapper to be installed etc.)

本文链接地址:https://www.jiuchutong.com/zhishi/277987.html 转载请保留说明!

上一篇:Win10系统如何更改窗口组件字体大小 Win10更改窗口组件字体大小方法(win10系统如何更改工作组)

下一篇:Linux系统下如何制作Live USB?Linux系统下制作Live USB的方法(linux小技巧)

  • 企业标准查询小微企业怎么查询

    企业标准查询小微企业怎么查询

  • 微博加粉丝的3个要点(新浪微博加粉)

    微博加粉丝的3个要点(新浪微博加粉)

  • oppok9s怎么设置电池百分比(oppok9s怎么设置来电转接)

    oppok9s怎么设置电池百分比(oppok9s怎么设置来电转接)

  • 腾讯会议怎么下载别人的录制(腾讯会议怎么下载)

    腾讯会议怎么下载别人的录制(腾讯会议怎么下载)

  • 苹果辅助球怎么打开(苹果辅助球怎么移动)

    苹果辅助球怎么打开(苹果辅助球怎么移动)

  • 华为黑屏无法唤醒(华为黑屏无法唤醒屏幕怎么解决)

    华为黑屏无法唤醒(华为黑屏无法唤醒屏幕怎么解决)

  • ipad官方给扩容吗(ipad官方扩容多少钱)

    ipad官方给扩容吗(ipad官方扩容多少钱)

  • 抖音隐藏了10个无效视频是什么意思(抖音隐藏了10个无效视频怎么删除)

    抖音隐藏了10个无效视频是什么意思(抖音隐藏了10个无效视频怎么删除)

  • 呼叫失败是对方挂了吗(呼叫失败是对方的问题还是我的问题)

    呼叫失败是对方挂了吗(呼叫失败是对方的问题还是我的问题)

  • bilibili属于哪个公司(bilibili属于哪个系)

    bilibili属于哪个公司(bilibili属于哪个系)

  • Excel取消自动筛选后会怎样(excel取消自动筛选后会怎样)

    Excel取消自动筛选后会怎样(excel取消自动筛选后会怎样)

  • 手机模型和手机的区别(手机模型和手机一样吗)

    手机模型和手机的区别(手机模型和手机一样吗)

  • ipad开不了机怎么办只显示白苹果(ipad开不了机怎么退出id)

    ipad开不了机怎么办只显示白苹果(ipad开不了机怎么退出id)

  • 安卓11新特性(安卓11的新特性)

    安卓11新特性(安卓11的新特性)

  • vivos1双引擎闪充在哪(vivos1双引擎闪充怎么开启)

    vivos1双引擎闪充在哪(vivos1双引擎闪充怎么开启)

  • 打印机如何调缩印(打印机怎样设置缩放)

    打印机如何调缩印(打印机怎样设置缩放)

  • 双11淘宝红包在哪里看(淘宝双11抢红包)

    双11淘宝红包在哪里看(淘宝双11抢红包)

  • 怎样关掉青少年模式(怎样关掉青少年守护模式)

    怎样关掉青少年模式(怎样关掉青少年守护模式)

  • oppo256g手机有哪些(oppo手机256g手机有哪些)

    oppo256g手机有哪些(oppo手机256g手机有哪些)

  • 时光加速器有什么用(时光加速器只能对自己用吗)

    时光加速器有什么用(时光加速器只能对自己用吗)

  • 预约滴滴快车怎么预约怎么预约(滴滴出行怎样预约快车)

    预约滴滴快车怎么预约怎么预约(滴滴出行怎样预约快车)

  • Mac Dock栏不见了怎么办?Dock栏消失解决办法(macos dock栏)

    Mac Dock栏不见了怎么办?Dock栏消失解决办法(macos dock栏)

  • 鸿蒙怎么删除路由器? 鸿蒙系统删除控制中心的路由器的技巧(如何删除鸿蒙)

    鸿蒙怎么删除路由器? 鸿蒙系统删除控制中心的路由器的技巧(如何删除鸿蒙)

  • YOLOV5网络结构设计的思考(yolov1网络结构图详解)

    YOLOV5网络结构设计的思考(yolov1网络结构图详解)

  • 路由器无线设置(路由器无线设置模式哪个更快)

    路由器无线设置(路由器无线设置模式哪个更快)

  • 北京市增值税发票
  • 市政道路工程建筑包括什么
  • 增值税发票的红章压到金额没有关系吧
  • 私对公转账收税吗
  • 固定资产直接计入成本的规定
  • 工资是当月计提下月发放吗
  • 出资款在现金流中怎么体现
  • 应收款项出售的分录怎么处理
  • 住房公积金个人和单位各承担多少
  • 非企业所得税税率
  • 不动产的进项税额分两年抵扣吗?
  • 定额发票验旧是什么意思
  • 已经提完折旧的固定资产报废
  • 会员卡充值赠送金额怎么做账
  • 施工现场应建立什么
  • 未开票收入是含税收入吗
  • 联营 保底
  • 一般纳税人转为小规模纳税人后还可以转为一般纳税人吗
  • 合伙企业利润分配个人所得税
  • 单位代缴住房公积金分录
  • 差额征税的项目有哪些
  • linux怎样使用
  • 投资性房地产期末公允价值大于账面价值
  • 我告诉你windows7旗舰版
  • 迷迭香怎么养殖方法
  • 哪些费用可以用医保
  • mysql跨库join
  • transformer中的参数
  • jQuery dom操作
  • seq命令
  • 可供出售金融资产的会计处理
  • mongodb最新版本
  • 织梦建站详细教程
  • 小微企业的税收优惠政策2023
  • 税控盘维护费280元怎么做账
  • 企业哪些账户可以取现金
  • 成本核算的意义与作用
  • 中小企业应交税费怎么算
  • 营改增后增加了什么征税项目
  • 发票金额比实际付款多怎么做账
  • 加计减免其他收入怎么填
  • 基建待摊费用如何分摊
  • 公司注销帐务怎么处理
  • 未分配利润期初余额怎么录入
  • 企业实缴各类税金的总额
  • 员工出国境有关说法
  • 报销需要发票吗?
  • 资产负债表与利润表的勾稽关系公式
  • 发票项目名称可以自定义吗
  • 设备丢失查找
  • 影响固定资产折旧的基本因素不包括
  • sql server 性能分析
  • mysql内存占用一直增高不释放
  • 系统存储过程以什么开头
  • 注册表隐藏桌面图标
  • win10的java环境该怎么配置?java环境变量配置介绍
  • ubuntu支持软件
  • debian修改中文
  • ubuntu fsl
  • centos7打开
  • centos6.5双网卡绑定
  • win10 win8.1双系统
  • linux的curl
  • android kotlin开发
  • vim安装ycm
  • js按下键盘事件
  • js实现登录界面
  • js怎样删除数组中的某个值
  • 安卓 aac
  • javax.net.ssl.SSLException: hostname in certificate didn't match:
  • python元祖内置函数
  • 使用mvc模式设计的web应用程序
  • javascript 继承
  • android存储方式
  • 江宁市民之家上班时间?
  • 公益性捐赠支出属于什么会计科目
  • 是否一般纳税人怎么查
  • 广州税务局前局长是谁
  • 贵州地方税务局网上办税服务厅
  • 湖北省税务发票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设