免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3710 | 回复: 2
打印 上一主题 下一主题

NFS的使用详细方法,给大家共享一下 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-06-09 15:19 |只看该作者 |倒序浏览
所有的测试环境都是sun的solaris系统。 \r\n\r\n1、理解nfs服务器和客户端功能。 \r\n\r\n   nfs是sun公司来建立来使用tcp/ip协议以及sun的远程调用和外部数据表示规范的产品。nfs的使用非常方便,也比较可靠。他具有在不同操作系统之间共享文件的能力。 \r\n   nfs服务器可以使用nfs来让其他远程机器共享它的本地资源。nfs客户机是访问nfs服务器的共享资源的机器。其实在实际工作中,一台主机即可以是nfs服务器,也可以是nfs客户机。他们可以互相共享和访问。 \r\n   只要你能理解nfs服务器和nfs客户机之间的不同。剩下的就很easy了。 \r\n\r\n2、 nfs服务器和nfs客户机区别。 \r\n2、1   solaris使用分布式文件系统或dfs命令公享资源。公享资源可以手动和自动设置。 \r\n    nfs服务器运行两个守侯进程:mountd 和 nfsd。 \r\n    用到的文件是: \r\n    /etc/rc3.d/S15nfs.server \r\n    /etc/dfs/dfstab \r\n    /etc/dfs/sharetab \r\n    /etc/rmtab \r\n    nfs服务器使用命令是:share unshare shareall unshareall \r\n\r\n   nfs客户机上运行的守侯进程是:statd 和 lockd。 \r\n   用到的文件是: \r\n   /etc/vfstab \r\n   /etc/mnttab \r\n   nfs客户机使用命令是:mount umount mountall umountall \r\n  \r\n2、2  nfs服务器设置 \r\n   nfs服务器需要运行两个守侯进程mountd和nfsd来工作。当nfs客户机试图访问一个远程的nfs服务器资源。nfs客户机通过mount命令请求与 nfs服务器的mountd守侯进程进行连接。当nfs服务器响应客户机时候,返回给可户机一个信息。客户机把这个信息写到本地的/etc/mnttab文件中。这个信息是服务器中共享文件和目录的信息。它是资源信息的编码:磁盘设备号、节点生成号、节点号等。这个是唯一的。 \r\n   一旦可户机得到请求信息,nfs服务器上的mountd进程就会在服务器本地的/etc/rmtab文件中添加一条信息。这是为了保持对当前加载可户机上文件的跟踪。这个文件为每一个被加载资源添加一个条目,格式是: \r\n remote hostname:  local filename name \r\n\r\n注意:mountd每一次重新启动和可户机发一个卸载请求,都会更新服务器的/etc/rmtab文件中的旧条目。 \r\n\r\n2、3 共享设置命令。 \r\n   明白了以上的道理,下面说具体的操作了。nfs服务器使用/usr/sbin/share命令为客户机共享资源。 \r\n  命令详解: \r\n  # share  ---显示所有可以安装的资源,不管它是否已经被安装。  \r\n  # share [ -F filesystem ] [ -o options ] [-d description ]  pathname-to-resource \r\n  ---指定共享文件。 \r\n  * -F  file system type 指定被公享的文件系统类型。 \r\n  * -o  options  指定客户对资源访问的类型。 \r\n  * -d  description  功享资源的简单描述。当你share命令不带任何参数运行,他就会被显示。 \r\n  * pathname-to-resource  在服务器上共享的资源名字。   \r\n------------------------------------------------------ \r\n  *-o  指定了允许客户访问共享资源的用户也权限。具体如下: \r\n  rw  表示用户可读/写,是默认植。 \r\n  rw=client1:client2  指定用户可以有读/写权限。可以有很多用户,用冒号分隔。 \r\n  ro  表示只读。 \r\n  ro=client1:client2  指定用户client1和client2只读。client1可以是用户名,也可以是ip地址,或者一个网段。例如:ro=@202.99.88.0/24 \r\n  root=client:client2 指定client1和client2上的root用户对共享资源有超级用户的权限。但是,他的优先级小于nfs服务器的本地权限。 \r\n   \r\n  例如:用户peng有个目录/exprot/home/games要共享。 \r\n  # share -F nfs -o rw=lnx3000:race , ro=@202.88.99.0/24:sune450 ,root=mmmmn -d \"i love MM !\" /export/home/peng/games  \r\n  运行结果:共享/exprot/home/peng/games目录,名字是lnx3000和race的两台主机有读/写权限;202.88.99.0这个c类网的机器和sun450这个主机只有读的权限;mmmmn这台主机的root用户可以对共享资源有超级用户访问权限。但是声名一点,要是我给共享目录/exprot/home/peng/games目录只读,mmmmn的root权限也没有用,只能只读。因为服务器本地权限大于任何share的权限。。 \r\n   \r\n  取消share资源。 \r\n  # unshare [ -F nfs ] path-to-resource \r\n  *  -F nfs 指定系统类型,默认。 \r\n  *  path-to-resource 指定共享路径。 \r\n  例如: \r\n   # unshare /export/home/peng/games  \r\n   取消这个共享资源了。 \r\n\r\n2、4 开机自动共享资源。 \r\n     以上的命令方法,在机器重新启动的时候,设置消失。如何保留和开机自动启动nfs共享。我们可以用/etc/dfs/dfstab文件来实现自动共享文件。只要主机启动进入运行级别3,nfs资源共享自动启动。 \r\n   1、编辑/etc/dfs/dfstab文件,添加: \r\n  share [ -F filesystem ] [ -o options ] [-d description ]  pathname-to-resource \r\n   -----这个和命令行是一样的。。。 \r\n  2、# /etc/init.d/nfs.server start  \r\n  这样就ok了。 \r\n   \r\n  3、手工快速命令。 \r\n  # shareall   --共享所有列在/etc/dfs/dfstab中的共享资源。 \r\n  # unshareall  --取消所有列在/etc/dfs/dfstab中的共享资源。 \r\n\r\n2、5 资源查看。 \r\n  # dfshares   \r\n  用以查看服务器的共享资源 。输入格式如下: \r\n  resource  server access  transprot \r\n  * resource  可被远程调用的资源的主机和路径名。 \r\n  * server   指定资源的系统名称。  \r\n  *  access  服务器指定的权限,默认是rw,显示为“-”。 \r\n  * transport  指定共享资源的端口。 \r\n\r\n  # dfmounts命令    \r\n  显示服务器上查看共享资源被利用的状况,输出格式如下:   \r\n  RESOURCE     SERVER PATHNAME                  CLIENTS \r\n  *  resource  共享资料名称。 \r\n  *  server pathname  共享资料目录。 \r\n  *  client  连接的客户端。 \r\n\r\n  # nfsstat  \r\n  看nfs的全部状态 \r\n\r\n3、nfs客户机设置。 \r\n   安装好nfs服务器后,就可以用客户端使用共享资料了。首先要检测nfs服务器,然后安装。 \r\n\r\n3、1 检测nfs服务器。 \r\n # showmount [ -ade ] <hostname>; \r\n * -a  显示已经已经使用的资源和来自哪个nfs服务器。 \r\n * -d  显示已经被远程安装的资源。 \r\n * -e  显示可以被安装的可以资源。一般用-e来查看远程主机的可以资源。 \r\n\r\n3、2 建立共享。 \r\n # mount [ -F nfs ] [ -o options ] path-to-resource path-to-local-mount-point \r\n * -F nfs  指定共享文件系统,默认的。没必要指定。 \r\n * -o options 指定选项,例如权限。默认rw,可读/写。也可以ro--只读。 \r\n * path-to-rescource  指定nfs服务器的主机名和共享资源路径。 \r\n * path-to-local-mount-point 指定共享资源在本地的mount点。 \r\n  \r\n 例如: \r\n # mkdir /export/home/games \r\n # mount peng:/export/home/peng/games /exprot/home/games \r\n  共享远程主机peng的/export/home/peng/games目录,可读写,挂接在本地的/exprot/home/games目录上。 \r\n\r\n3、3取消共享。 \r\n# umount [-F nfs] remote-path-to-resource path-to-local-mount-point \r\n* -F nfs  默认的文件系统。 \r\n* remote-path-to-resource 远程主机和共享目录路径,主机和共享目录路径用冒号分隔。 \r\n* path-to-local-mount-point  本地主机挂点。 \r\n\r\n例如: \r\n# umount peng:/export/home/peng/games /export/home/games \r\n取消远程主机peng上的/exprot/home/peng/games这个目录的在本地/export/home/games上的共享。 \r\n\r\n3、4 系统开机自动共享。 \r\n  修改/etc/vfstab文件,格式如下:   \r\ndevice to mount   device to fsck   mount point  FS type   fsck pass   mount at boot   mount options \r\n\r\n*  device to mount 指定远程服务器名和共享路径。远程服务器名和共享路径用冒号分开。 \r\n*  device to fsck  这个是空的。从来不从客户机进行文件检测。 \r\n*  mount point  指定本地的mount点。这个目录必须是已经存在的。 \r\n*  FS type  对于nfs资源系统来说,当然是nfs了。 \r\n*  fsck pass  这个也是空的。表示不从客户机进行文件系统检测。 \r\n*  mount at boot 选择yes or no,yes就是启动时自动安装。 \r\n*  mount options 用逗号分隔的mount命令的列表。 \r\n\r\n例如: \r\n # vi /etc/vfstab 添加: \r\n peng:/export/home/peng/games - /export/home/games nfs - yes soft,bg \r\n\r\n表示开机自动把远程主机peng的/export/home/peng/games目录自动挂到本机的/export/home/games下。soft选项是目录不能安装,产生一个错误。bg选项,系统启动过程中安装在后台。 \r\n关于mount options的参数,请用 man mount 自己看看吧。   \r\n  \r\n 3、5 手工调试命令。 \r\n# mountall  \r\n  不带任何参数,安装所有列在/etc/vfstab文件中mount at boot中为yes的资源。 \r\n# mountall -r 只影响远程文件 \r\n# mountall -l 只影响本地文件 \r\n\r\n# umountall \r\n  不带任何参数,谢载已经安装的资源。不包括/ 、/proc、/usr、/var。另外,系统忙,也可能不会卸载。 \r\n# umountall -r 只影响远程文件 \r\n# umountall -l 只影响本地文件 \r\n\r\n小节: \r\n   到这里我想应该没有什么问题了。 \r\n   大家只要注意一下客户端和服务器端的区分。 \r\n   nfs服务器端运行守侯进程mound、nfsd \r\n   nfs服务器端使用文件/etc/dfs/dfstab、/etc/dfs/sharetab、/etc/rmtab \r\n   nfs服务器使用命令是:share unshare shareall unshareall \r\n    \r\n   nfs客户端运行守侯进程statd、lockd。 \r\n   用到的文件是/etc/vfstab、/etc/mnttab \r\n   nfs客户机使用命令是:mount umount mountall umountall \r\n   知道这些,就ok了。 \r\n\r\nFAQ : \r\n1、运行mount命令不能得到共享资源,得到信息:“nfs server not responding”。            \r\nanswer:确信服务器上nfsd和mountd已经运行,资源已经用共享命令正确共享。   \r\n2、当我企图共享到本地磁盘时,错误为:“mount:/tmp_mount not found”. \r\nanswer: 你有没有在本地创建mount点。。。

论坛徽章:
0
2 [报告]
发表于 2005-06-09 17:55 |只看该作者

NFS的使用详细方法,给大家共享一下

没看过这么全面描述NFS的, 好!

论坛徽章:
0
3 [报告]
发表于 2005-06-10 08:25 |只看该作者

NFS的使用详细方法,给大家共享一下

呵呵,写的比较好,抄的也比较好。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP