Centos 6搭建NFS服务器及相关问题解决

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等

时间: 2024-08-10 21:30:05

Centos 6搭建NFS服务器及相关问题解决的相关文章

CentOS下搭建NFS服务器总结

环境介绍: 1. 服务器: 192.168.0.100 2. 客户机: 192.168.0.101 安装软件包: 1. 服务器和客户机都要安装nfs 和 rpcbind 软件包: yum -y install nfs-utils rpcbind 2. 可用以下命令查看,是否已经安装了nfs-uitls rpcbind这两个软件包:如果查询结果如下面所示,说明已经安装过了: [[email protected] ~]# rpm -qa|grep nfs nfs-utils-1.2.3-39.el6

Centos6.4搭建NFS 服务器实例(四)

Centos6.4搭建NFS 服务器实例: 服务器系统 角色 IP CentOS-64-121-server1 NFS服务器端 192.168.1.121 CentOS-64-129-client NFS客户端 192.168.1.129 共享CentOS-64-121-server1中/data/bbs目录,使192.168.1.1 IP段所有主机都可以访问 配置服务端: 首先创建实验环境目录 [[email protected] ~]# mkdir /data/bbs –p [[email 

Centos5.8搭建NFS 服务器实例(三)

Centos5.8搭建NFS 服务器实例: 服务器系统 角色 IP CentOS-5.8-111-server1 NFS服务器端 192.168.1.111 CentOS-5.8-119-client NFS客户端 192.168.1.119 共享CentOS-5.8-111-server1中/data/bbs目录,使192.168.1.1 IP段所有主机都可以访问 配置服务端: 首先创建实验环境目录 [[email protected] ~]# mkdir /data/bbs –p [[ema

CentOS系统下NFS服务器

NFS服务器 NFS是Network File System的缩写,功能可将其简单的看作一个文件服务器,可以通过网络,使不同的主机和不同操作系统可以共享文件. 现在尤其在机房是Linux集群的环境下,几十或者几百台服务器,使用NFS共享文件,可以极大保证效率. 配置环境: VMware虚拟机,安装两台CentOS 6.5服务器 NFS-Server: IP:192.168.30.129 共享目录:/data NFS-Client: IP:192.168.30.130 挂载目录:/data 在服务

centos下搭建dhcp服务器

centos下搭建dhcp服务器 一.软件环境 CentOS release 6.5 dhcp-4.1.1-51.P1.el6.centos.x86_64 dhcp-common-4.1.1-51.P1.el6.centos.x86_64 二.网络拓扑 dhcp服务器--H3c交换机(7503)-- H3c交换机(5500)-- H3c交换机(3100)--dhcp客户端(办公电脑) 网段: 10.2.240.0/24 10.2.180.0/24 dhcp服务器ip:10.2.33.253 三.

RedHat搭建NFS服务器

首先说一下什么是NFS,其实就是Network File System的缩写,是sun公司开发的.能够实现不同的机器,不同的操作系统乐意彼此共享文件.在我前面的文章中有提到Samba,它也是一种文件共享服务器.不同的是,NFS实现的是linux客户机之间的文件共享,而Samba主要是为了实现windows和linux之间的文件共享,前者相对简单,后者相对复杂,但是复杂必然有复杂的道理. 下面我介绍下如何搭建NFS服务器,以及客户机如何能够实现文件共享: 场景 某单位需要配置 NFS 服务器, 为

【CentOS】搭建Web服务器

参考资料: http://www.paipat.com/?post=24 http://www.cnblogs.com/xiaoluo501395377/archive/2013/04/07/3003278.html 1.安装apache 2.安装php 3.安装mysql 1.安装apache 安装:直接使用yum安装apache:yum install httpd rpm使用: 格式:rpm  -q[子选项][软件名] 用法:结合不同的子选项,完成不同的查询 -qa   : 查看系统中已安装

【CentOS】搭建svn服务器

搭建snv服务器步骤: 1.安装httpd 2.安装svn 3.配置 4.windows安装Tortoisesvn 参考资料: svn server安装:http://blog.csdn.net/colinchan/article/details/1865154 svn配置:http://www.if-not-true-then-false.com/2010/install-svn-subversion-server-on-fedora-centos-red-hat-rhel/ ra_dav 问

基于NFS v4版本搭建NFS服务器

基于NFS  v4版本搭建NFS服务器 1资源规划 作用 IP 版本 NFS服务端 192.168.78.1 Centos6.5 64位 NFS客户端 192.168.78.1 Centos6.5 64位 2 NFS服务端安装配置 2.1 安装rpm包 yum install  nfs-utils  nfs-utils-lib  nfs4-acl-tools rpcbind 2.2 新建要导出的目录 mkdir  -pv  /home/data/ mkdir  -pv  /home/nfs/ 2