NFS 是Network File System的缩写,即网络文件系统。一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布。功能是通过网络让不同的机器、不同的操作系统能够彼此分享个别的数据,让应用程序在客户端通过网络访问位于服务器磁盘中的数据,是在类Unix系统间实现磁盘文件共享的一种方法。
应用场景:
在生产环境中一系统因架构变化后,把一模块原有的单节点扩展成了两个节点,前端采用用nginx做负载的架构,而这两个节点需要一个公共的存储来存放用户上传的图片,用户的并发不高,再因原有业务模块是从nginx主机上剥离出来的,在原nginx主机上有“img”这个存储图片的目录,所以考虑在nginx主机上安装nfs服务,再在两个节点上同点挂载“img”目录实现集群节点对图片目录的访问。NFS服务的安装比较简单,但在上生产环境时还是应该在自己的测试环境先验证,这里把安装过程记录如下:
系统环境:centos 6.4 x86_64
服务器3台:10、12(客户端);21(服务端)
1、检查系统是否开启nfs服务:service nfs status 结果显示nfs: unrecognized service,说明系统没有安装nfs服务,注意,yum install nfs是无法安装的,应该用yum install nfs-utils.
2、开启portmap服务,还是unrecognized service ,安装之,yum install portmap 未果,百度+google之,发现centos 6.4中portmap 已经被rpcbind取代,于是乎继续安装之,未果,检查下是不是已经在安装nfs-utils包的时候安装了,service rpcbind status ,果然已经一块安装了。
以上为整个安装过程,总结下就是centos 6.x之后的系统一个命令yum install nfs-utils 全部搞定,貌似5.x版本的也可以用这个命令搞定,搞不定的话可以单独装portmap;主要6.x版本用的事rpcbind, 5.x版本用的是portmap。
下面是启动过程:
1、首先配置/etc/exports文件
vi /etc/exports;
然后输入 /opt/pic:192.168.1.1/255.255.255.0(rw,sync,no_root_squash,no_all_squash)
保存退出
2、启动rpcbind服务 service rpcbind start
3、启动nfs服务 service nfs start
showmount -e 192.168.1.21 输出以下结果:
Export list for 192.168.1.21:
/opt/pic 192.168.1.1/255.255.255.0
说明成功启动(注意:在centos 6.x之后的版本showmount -e 后面一定要指定ip,否则会卡在那,也没输出,5.x的版本可以不指定)
下面是挂载nfs到指定机器的目录
ssh登陆到一台机器b:ssh [email protected]
mount -t nfs 192.168.1.21:/opt/pic /opt/pic
在a机器上建立文件test.txt,然后发现b机器有了同样的文件,nfs服务端和客户端正常同步。
操作其实不算太难,不过中间也发生了一些小问题和注意事项,在此也一起讲讲
1. /etc/exports文件内容格式:
<输出目录> [客户端1 选项(访问权限,用户映射,其他)] [客户端2 选项(访问权限,用户映射,其他)]
2. insecure 当mount监听端口大于1024时需要使用此参数
3.权限配置参数
rw read-write,可读写;
sync:文件同时写入硬盘和内存;
async:文件暂存于内存,而不是直接写入内存;
no_root_squash:NFS客户端连接服务端时如果使用的是root的话,那么对服务端分享的目录来说,也拥有root权限。显然开启这项是不安全的。
4. 重新加载/etc/exports的配置:
[[email protected] ~]# exportfs -r
5. 客户端配置
在客户端只需要安装nfs-client端,如果没有client端程序,直接安装nfs-utils
6. 根据需要设置访问权限
[[email protected] ~]#vi /etc/hosts.allow
[[email protected] ~]#vi /etc/hosts.deny
7. 挂载格式:
mount –t nfs hostname(or IP):/directory /mount point
卸载:
umount /本地挂载目录(本地client卸载方法,但用exports –au为server卸载)
设置自动挂载:
在服务器端:chkconfig --add rpcbind&&nfs
在客户端:打开/etc/fstab,在最后一行添加如下信息:
192.168.1.21:/usr/pic /opt/pic nfs defaults 0 0
8. 查看共享
showmount –e IP(查看NFS服务器上共享了那些目录)
showmount –a IP(用于nfs server上,显示已经mount上本机NFS服务器的client(客户机))
今天碰到一个nfs挂载错误的问题,错误提示如下:
mount: wrong fs type, bad option, bad superblock on ***,
missing codepage or helper program, or other error
(for several filesystems (e.g. nfs, cifs) you might
need a /sbin/mount.<type> helper program)
In some cases useful info is found in syslog - try
dmesg | tail or so
根据错误提示,查看/sbin/mount.<type>文件,果然发现没有/sbin/mount.nfs的文件,安装nfs-utils即可
解决方法:yum install nfs-utils
安装之后,/sbin/下面多了两个mount文件,分别是mount.nfs和mount.nfs4:
[[email protected] data]# ll /sbin/mount*
-rwsr-xr-x. 1 root root 123776 11月 22 2013 /sbin/mount.nfs
lrwxrwxrwx. 1 root root 9 6月 9 13:41 /sbin/mount.nfs4 -> mount.nfs
-rwxr-xr-x. 1 root root 1338 2月 22 2013 /sbin/mount.tmpfs
NFS共享服务挂载时出现“access denied by server while mounting”的解决方法
修改/etc/sysconfig/nfs文件,将
# Turn off v2 and v3 protocol support
# RPCNFSDARGS="-N 2 -N 3"
# Turn off v4 protocol support
#RPCNFSDARGS="-N 4" /*把这句话的#号去掉*/
NFS分为三个版本,即NFS-2 NFS-3 NFS-4,该配置文件默认关闭了这三个的NFS版本,我们只需要打开NFS-4即可。
最后再说说题外话,NFS 允许用户像访问本地文件一样,去访问网络上共享的文件。NFS 是一個成功的文件共享方法,但它最大的问题是它不太适合大型的分散式系統。那么大量用户上传的文件的存储应该采用什么文件系统呢,貌似fastdfs不错,与之类似的还有MogileFS等