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

[经验分享] CentOS 6.7 安装配置nfs 服务

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-11-6 09:34:49 | 显示全部楼层 |阅读模式
NFS 是Network File System的缩写,即网络文件系统。它功能是通过网络让不同的机器、不同的操作系统能够彼此分享各自的数据,让应用程序在客户端通过网络访问位于服务器磁盘中的数据。

NFS在文件传送或信息传送过程中依赖于RPC协议。RPC:远程过程调用(Remote Procedure Call) 是能使客户端执行其他系统中程序的一种机制。NFS本身是没有提供信息传输的协议和功能的,但NFS却能让我们通过网络进行资料的分享,这是因为NFS使用了一些其它的传输协议。而这些传输协议用到这个RPC功能的。可以说NFS本身就是使用RPC的一个程序。或者说NFS也是一个RPC SERVER。所以只要用到NFS的地方都要启动RPC服务,不论是NFS SERVER或者NFS CLIENT。这样SERVER和CLIENT才能通过RPC来实现PROGRAM PORT的对应。可以这么理解RPC和NFS的关系:NFS是一个文件系统,而RPC是负责信息的传输。

所以,我们需要安装两个软件包:nfs-utils和rpcbind,在centOS 5中rpcbind 叫portmap,作用都是一样的,名字不同而已。

安装方式:yum安装
nfs服务端:balichvm(192.168.171.51)

客户端:balichos(192.168.171.50)

安装步骤:

1)、在balichvm上安装nfs-utils和rpcbind,使用yum 安装,如下:
[iyunv@balichvm ~]# yum install –y nfs-utilsrpcbind                                   

2)、在balichvm建立需要分享的目录和编辑配置文件/etc/exports(这个文件默认没有)
[iyunv@balichvm ~]# mkdir –p /data/nfsdata
[iyunv@balichvm ~]#vim /etc/exports
/data/nfsdata/  192.168.171.0/24 (rw,sync,root_squash)

这里的配置是共享目录/data/nfsdata/;网段192.168.171.0的主机可以有读写权限、限制root权限、同步到磁盘)
/etc/exports配置文件的格式和选项有:
格式:共享的目录         共享给那些网段的主机         共享的权限

选项:(共享的权限)

ro:——只读;
rw:——读写;
sync :——同步模式,内存中数据时时写入磁盘;
async :——不同步,把内存中数据定期写入磁盘中;
no_root_squash :——加上这个选项后,root用户就会对共享的目录拥有至高的权限控制,就像是对本机的目录操作一样。不安全,不建议使用;
root_squash:——和上面的选项对应,root用户对共享目录的权限不高,只有普通用户的权限,即限制了root;
all_squash:——不管使用NFS的用户是谁,他的身份都会被限定成为一个指定的普通用户身份;
anonuid/anongid :——要和root_squash以及all_squash一同使用,用于指定使用NFS的用户限定后的uid和gid,前提是本机的/etc/passwd中存在这个uid和gid。

3)、在balichvm配置防火墙规则,编辑/etc/sysconfig/nfs,固定服务的端口,默认是注释的,需要打开。
# Port rpc.mountd should listen on.
MOUNTD_PORT=892                             #把前面的#号去掉

# Port rquotad should listen on.
RQUOTAD_PORT=875                             #把前面的#号去掉

# TCP port rpc.lockd should listen on.
LOCKD_TCPPORT=32803                           #把前面的#号去掉

# UDP port rpc.lockd should listen on.
LOCKD_UDPPORT=32769                        #把前面的#号去掉

这些端口是配置文件默认的,是可以自行修改增加需要的端口号,然后保存配置文件。

然后启动rpdbind 和nfs 服务:
/etc/init.d/rpcbind restart
/etc/init.d/nfs restart

服务启动后,使用rpcinfo –p 查看启用的端口。
[iyunv@balichvm ~]# rpcinfo -p
  program vers proto   port  service
   100000    4   tcp   111  portmapper
   100000    3   tcp   111  portmapper
   100000    2   tcp   111  portmapper
   100000    4   udp   111  portmapper
   100000    3   udp   111  portmapper
   100000    2   udp   111  portmapper
   100005    1   udp   892  mountd
   100005    1   tcp   892  mountd
   100005    2   udp   892  mountd
   100005    2   tcp   892  mountd
   100005    3   udp   892  mountd
   100005    3   tcp   892  mountd
   100003    2   tcp  2049  nfs
   100003    3   tcp  2049  nfs
   100003    4   tcp  2049  nfs
   100227    2  tcp   2049  nfs_acl
   100227    3   tcp  2049  nfs_acl
   100003    2   udp  2049  nfs
   100003    3   udp  2049  nfs
   100003    4   udp  2049  nfs
   100227    2   udp  2049  nfs_acl
   100227    3   udp  2049  nfs_acl
   100021    1   udp 32769  nlockmgr
   100021    3   udp 32769  nlockmgr
   100021    4   udp 32769  nlockmgr
   100021    1   tcp 32803  nlockmgr
   100021    3   tcp 32803  nlockmgr
   100021    4   tcp 32803  nlockmgr
[iyunv@balichvm ~]#

将这些启用的端口(tcp和udp)写到iptables防火墙里面(vim /etc/sysconfig/iptables),允许通过,如下:

-A INPUT -m state --state NEW -m tcp -p tcp--dport 111 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp--dport 892 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp--dport 2049 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp--dport 32769 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp--dport 32803 -j ACCEPT
-A INPUT -m state --state NEW -m udp -p udp--dport 111 -j ACCEPT
-A INPUT -m state --state NEW -m udp -p udp--dport 892 -j ACCEPT
-A INPUT -m state --state NEW -m udp -p udp--dport 2049 -j ACCEPT
-A INPUT -m state --state NEW -m udp -p udp--dport 32769 -j ACCEPT
-A INPUT -m state --state NEW -m udp -p udp--dport 32803 -j ACCEPT

然后重启iptables服务:/etc/init.d/iptables restart

4)、在客户端balichos上,安装nfs-utils,并且挂载balichvm共享的nfsdata目录,查看某台主机共享的nfs使用命令showmount–e ip(主机名)。
[iyunv@balichOS ~]# yum install –y nfs-utils
[iyunv@balichOS ~]# showmount -e192.168.171.51                          ##查看共享的nfs
Export list for 192.168.171.51:
/data/nfsdata 192.168.171.0/24
[iyunv@balichOS ~]#

[iyunv@balichOS ~]# mount -t nfs192.168.171.51:/data/nfsdata/ /mnt/
[iyunv@balichOS ~]# df -h
Filesystem     Size      Used     Avail      Use%       Mountedon
/dev/sda3      18G      5.9G     11G        36%        /
tmpfs        495M     0      495M        0%         /dev/shm
/dev/sda1      190M    36M      145M        20%         /boot
192.168.171.51:/data/nfsdata/  18G  3.8G   13G    24%        /mnt

现在就已经挂载了一个文件系统,但是由于在balichvm上/data/nfsdata的权限是755,其他用户不具备写的权限,而在nfs配置文件/etc/exports上又限定了root用户权限,默认是使用其他的用户的登录,所有无法写入数据,只有读取的权限。
如果需要有写入的权限,可以修改权限。



运维网声明 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-135731-1-1.html 上篇帖子: centos7基础运维环境搭建 下篇帖子: ssh-keygen 实现免密码登录远程服务器
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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