设为首页 收藏本站
查看: 490|回复: 0

[经验分享] 搭建NFS文件共享--实例解析

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-1-3 13:12:57 | 显示全部楼层 |阅读模式
1 NFS简介
   NFS 是Network File System的缩写,即网络文件系统。一种使用于分散式文件系统的协定,由Sun公
司开发,于1984年向外公布。功能是通过网络让不同的机器、不同的操作系统能够彼此分享个别的数据,
让应用程序在客户端通过网络访问位于服务器磁盘中的数据,是实现磁盘文件共享的一种方法。
  NFS 的基本原则是“容许不同的客户端及服务端通过一组RPC分享相同的文件系统”,它是独立于操作
系统,容许不同硬件及操作系统的系统共同进行文件的分享。

2 NFS服务器的配置
NFS服务器的配置相对比较简单,只需要在相应的配置文件中进行设置,然后启动NFS服务器即可。
NFS的常用目录
/etc/exports                           NFS服务的主要配置文件
/usr/sbin/exportfs                   NFS服务的管理命令
/usr/sbin/showmount              客户端的查看命令
/var/lib/nfs/etab                      记录NFS分享出来的目录的完整权限设定值
/var/lib/nfs/xtab                      记录曾经登录过的客户端信息
NFS服务的配置文件为 /etc/exports,这个文件是NFS的主要配置文件,不过系统并没有默认值,所以这个文件不一定会存在,可能要使用vim手动建立,然后在文件里面写入配置内容。
/etc/exports文件内容格式:
<输出目录> [客户端1 选项(访问权限,用户映射,其他)] [客户端2 选项(访问权限,用户映射,其他)]


输出目录是指NFS系统中需要共享给客户机使用的目录;
客户端是指网络中可以访问这个NFS输出目录的计算机;
选项用来设置输出目录的访问权限、用户映射等。
NFS主要有3类选项:
访问权限选项
设置输出目录只读:ro
设置输出目录读写:rw
用户映射选项
all_squash:将远程访问的所有普通用户及所属组都映射为匿名用户或用户组(nfsnobody);
no_all_squash:与all_squash取反(默认设置);
root_squash:将root用户及所属组都映射为匿名用户或用户组(默认设置);
no_root_squash:与rootsquash取反;
anonuid=xxx:将远程访问的所有用户都映射为匿名用户,并指定该用户为本地用户(UID=xxx);
anongid=xxx:将远程访问的所有用户组都映射为匿名用户组账户,并指定该匿名用户组账户为本地用户组账户(GID=xxx);
其它选项
secure:限制客户端只能从小于1024的tcp/ip端口连接nfs服务器(默认设置);
insecure:允许客户端从大于1024的tcp/ip端口连接服务器;
sync:将数据同步写入内存缓冲区与磁盘中,效率低,但可以保证数据的一致性;
async:将数据先保存在内存缓冲区中,必要时才写入磁盘;
wdelay:检查是否有相关的写操作,如果有则将这些写操作一起执行,这样可以提高效率(默认设置);
no_wdelay:若有写操作则立即执行,应与sync配合使用;
subtree:若输出目录是一个子目录,则nfs服务器将检查其父目录的权限(默认设置);
no_subtree:即使输出目录是一个子目录,nfs服务器也不检查其父目录的权限,这样可以提高效率;

3 实例解析
服务端配置192.168.1.6
通过nfs服务,把主机192.168.1.6的/home/web与/home/data共享出去
[iyunv@localhost ~]# yum install -y nfs-utils rpcbind  #安装nfs和rpcbind
[iyunv@localhost ~]# rpm -qa|grep nfs-utils        #查看安装结果
nfs-utils-lib-1.1.5-11.el6.x86_64
nfs-utils-1.2.3-70.el6_8.2.x86_64
[iyunv@localhost ~]# rpm -qa|grep rpcbind        #查看安装结果
rpcbind-0.2.0-12.el6.x86_64


[iyunv@localhost ~]# mkdir /home/{web,data}        #创建共享目录
[iyunv@localhost ~]# chmod a+w /home/web         #给共享目录添加写权限
[iyunv@localhost ~]# vim /etc/exports            #添加配置文件内容
/home/web 192.168.1.5(rw,async,no_root_squash)
/home/data 192.168.1.5(ro,sync)
[iyunv@localhost ~]# /etc/init.d/rpcbind restart      #重启rpc

停止 rpcbind:                                             [确定]
正在启动 rpcbind:                                         [确定]
[iyunv@localhost ~]# /etc/init.d/nfs restart        #重启nfs
关闭 NFS 守护进程:                                        [失败]
关闭 NFS mountd:                                          [失败]
关闭 NFS quotas:                                          [失败]
启动 NFS 服务:                                            [确定]
关掉 NFS 配额:                                            [确定]
启动 NFS mountd:                                          [确定]
启动 NFS 守护进程:                                        [确定]
正在启动 RPC idmapd:                                      [确定]
[iyunv@localhost ~]# chkconfig rpcbind on        #添加到开机启动
[iyunv@localhost ~]# chkconfig nfs on

客户端操作192.168.1.5
[iyunv@localhost ~]# showmount -e 192.168.1.6    #查看服务器端列表
Export list for 192.168.1.6:
/home/data 192.168.1.5
/home/web  192.168.1.5
[iyunv@localhost ~]# mkdir /web            #创建挂载目录
[iyunv@localhost ~]# mkdir /data
[iyunv@localhost ~]# df
Filesystem     1K-blocks    Used Available Use% Mounted on
/dev/sda3       18344828 1017808  16388476   6% /
tmpfs             502384       0    502384   0% /dev/shm
/dev/sda1          95054   27170     62764  31% /boot
[iyunv@localhost ~]# mount 192.168.1.6:/home/web /web    #将服务端的共享挂载
[iyunv@localhost ~]# mount 192.168.1.6:/home/data /data
[iyunv@localhost ~]# df
Filesystem           1K-blocks    Used Available Use% Mounted on
/dev/sda3             18344828 1017812  16388472   6% /
tmpfs                   502384       0    502384   0% /dev/shm
/dev/sda1                95054   27170     62764  31% /boot
192.168.1.6:/home/web        18244480 6994432  10316544  41% /web
192.168.1.6:/home/data        18244480 6994432  10316544  41% /data
[iyunv@localhost ~]# echo "192.168.1.6:/home/web /web nfs defaults 0 0" >> /etc/fstab
设置开机挂载
[iyunv@localhost ~]# echo "192.168.1.6:/home/data  /data nfs defaults 0 0" >> /etc/fstab
[iyunv@localhost ~]# chmod a+w /web        #添加写权限
[iyunv@localhost ~]# cd /web
[iyunv@localhost web]# ls
[iyunv@localhost web]# mkdir test
[iyunv@localhost web]# touch text
[iyunv@localhost web]# ll
总用量 4
drwxr-xr-x. 2 root root 4096 1月   2 16:18 test
-rw-r--r--. 1 root root    0 1月   2 16:18 text

回到客户端192.168.1.6查看
[iyunv@localhost ~]# cd /home/web        说明一切正常
[iyunv@localhost web]# ls
test  text


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-323329-1-1.html 上篇帖子: chattr加锁文件引起yum更新时报错处理 下篇帖子: Red Hat Linux使用yum 安装报 关于Public key for *.rpm is not installed...
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表