首页 > 代码库 > RedHat搭建NFS服务器

RedHat搭建NFS服务器

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

下面我介绍下如何搭建NFS服务器,以及客户机如何能够实现文件共享:

  1. 场景

某单位需要配置 NFS 服务器, 为另外一台运行 Oracle 数据库的 Linux 服务器提供备份存储。 

wKioL1QKYXeR3PpxAABxZDHisI4293.png

主机名               IP 地址            

nfs1.abc.local    192.168.1.241 

db1.abc.local     192.168.1.242 

2. 实验环境 

2.1. 操作系统安装 

# cat /etc/redhat-release  

Red Hat Enterprise Linux Server release 6.4 (Santiago) 

# uname -a 

Linux localhost.localdomain 2.6.32-358.el6.x86_64 #1 SMP Tue Jan 29 

11:47:41 EST 2013 x86_64 x86_64 x86_64 GNU/Linux 

2.2. 服务器基本配置 

修改 IP 地址。 (注意:根据您的实现环境进行配置) 

# vi /etc/sysconfig/network-scripts/ifcfg-eth0 

DEVICE=eth0 

TYPE=Ethernet 

ONBOOT=yes 

NM_CONTROLLED=yes 

BOOTPROTO=static 

IPADDR=192.168.1.241 

NETMASK=255.255.255.0 

GATEWAY=192.168.1.1 

 

修改主机名 

# vi /etc/sysconfig/network 

NETWORKING=yes 

#HOSTNAME=localhost.localdomain 

HOSTNAME=nfs1.abc.local 

 

# service network restart 

 

为了方便实验,将防火墙关闭。 

# service iptables stop 

# chkconfig iptables off 

同时关闭 selinux。

# vi /etc/sysconfig/selinux 

# This file controls the state of SELinux on the system. 

# SELINUX= can take one of these three values: 

#     enforcing - SELinux security policy is enforced. 

#     permissive - SELinux prints warnings instead of enforcing. 

#     disabled - No SELinux policy is loaded. 

#SELINUX=enforcing 

SELINUX=disabled 

# SELINUXTYPE= can take one of these two values: 

#     targeted - Targeted processes are protected, 

#     mls - Multi Level Security protection. 

SELINUXTYPE=targeted  

 

重新启动以便生效。 

# reboot

3. NFS 服务器安装与配置 

3.1. 安装 NFS 服务器组件 

3.1.1. 方法 1:通过 RPM 来进行安装 

# mkdir /mnt/cdrom 
# mount /dev/cdrom /mnt/cdrom/ 
mount: block device /dev/sr0 is write-protected, mounting read-only 
# cd /mnt/cdrom/Packages/  
# ls nfs* 
nfs4-acl-tools-0.3.3-6.el6.x86_64.rpm  
nfs-utils-1.2.3-36.el6.x86_64.rpm  
nfs-utils-lib-1.1.5-6.el6.i686.rpm  
nfs-utils-lib-1.1.5-6.el6.x86_64.rpm 
# rpm -ivh nfs-utils-1.2.3-36.el6.x86_64.rpm  
error: Failed dependencies: 
        keyutils >= 1.4-4 is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
        libevent is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
        libevent-1.4.so.2()(64bit) is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
        libgssglue is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
        libgssglue.so.1()(64bit) is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
        libgssglue.so.1(libgssapi_CITI_2)(64bit) is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
        libnfsidmap.so.0()(64bit) is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
        libtirpc is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
        libtirpc.so.1()(64bit) is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
        nfs-utils-lib >= 1.1.0-3 is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
        rpcbind is needed by nfs-utils-1:1.2.3-36.el6.x86_64 
解决包的依赖性 
# rpm -ivh nfs-utils-1.2.3-36.el6.x86_64.rpm \ 
nfs-utils-lib-1.1.5-6.el6.x86_64.rpm \ 
rpcbind-0.2.0-11.el6.x86_64.rpm keyutils-1.4-4.el6.x86_64.rpm  \ 
libevent-1.4.13-4.el6.x86_64.rpm \ 
libgssglue-0.1-11.el6.x86_64.rpm  \ 
libtirpc-0.2.1-5.el6.x86_64.rpm  
Preparing...                ########################################### [100%] 
   1:libgssglue             ########################################### [ 14%] 
   2:libtirpc               ########################################### [ 29%] 
   3:rpcbind                ########################################### [ 43%] 
   4:libevent               ########################################### [ 57%] 
   5:keyutils               ########################################### [ 71%] 
   6:nfs-utils-lib          ########################################### [ 86%] 
   7:nfs-utils              ########################################### [100%]

 

3.1.2. 方法 2:通过 YUM 来进行安装 

通过 YUM 来解决包的相关性,需要配置yum源 

# mkdir /mnt/cdrom 
# mount /dev/cdrom /mnt/cdrom/ 
mount: block device /dev/sr0 is write-protected, mounting read-only  
# vi /etc/yum.repos.d/rhel-dvd.repo 
创建新的文件,添加如下内容: 
[rhel-dvd] 
name=Red Hat Enterprise Linux $releasever - $basearch - DVD 
baseurl=file:///mnt/cdrom/Server/ 
enabled=1 
gpgcheck=1 
gpgkey=file:///mnt/cdrom/RPM-GPG-KEY-redhat-release 
# yum list | grep nfs 
nfs-utils.x86_64           1:1.2.3-36.el6  rhel-dvd  
nfs-utils-lib.i686         1.1.5-6.el6     rhel-dvd  
nfs-utils-lib.x86_64       1.1.5-6.el6     rhel-dvd  
nfs4-acl-tools.x86_64      0.3.3-6.el6     rhel-dvd  
sblim-cmpi-nfsv3.i686      1.1.1-1.el6     rhel-dvd  
sblim-cmpi-nfsv3.x86_64    1.1.1-1.el6     rhel-dvd  
sblim-cmpi-nfsv4.i686      1.1.0-1.el6     rhel-dvd  
sblim-cmpi-nfsv4.x86_64    1.1.0-1.el6     rhel-dvd   
# yum -y install nfs-utils

很方便地就安装完毕了

3.2. 启动 NFS 服务 

NFS 依赖 rpcbind 服务,设置为其自动启动

由于nfs服务依赖于rpc(远程过程调用)服务,所以在启动nfs服务之前,需要先启动rpc服务

# chkconfig rpcbind on 
# service rpcbind start 
# service nfs start 
Starting NFS services:                                     [  OK  ] 
Starting NFS quotas:                                       [  OK  ] 
Starting NFS mountd:                                       [  OK  ] 
Starting NFS daemon:                                       [  OK  ] 
# tail /var/log/messages 中 
rpc.mountd[1797]: Version 1.2.3 starting 
kernel: NFSD: Using /var/lib/nfs/v4recovery as the NFSv4 state 
recovery directory 
kernel: NFSD: starting 90-second grace period 
# chkconfig nfs on

3.3. 配置 NFS 服务器 

查看当前共享的 NFS 信息 

# showmount -e localhost 

Export list for localhost: 空白无输出 

 

下面,做一个最基础的测试。创建 export 目录,分配权限 

# mkdir /nfsdata 

# ll /nfsdata/ -d 

drwxr-xr-x 2 root root 4096 Jul 31 15:16 /nfsdata/ 

# chmod a+w /nfsdata/ 

# ll /nfsdata/ -d 

drwxrwxrwx 2 root root 4096 Jul 31 15:16 /nfsdata/ 

 

配置 export 文件 

# vi /etc/exports 

添加如下内容,注意选项中逗号之间没有空格! 

/nfsdata *(rw,root_squash,no_all_squash,sync)

这里的意思是说,需要共享/nfsdata这个目录,对所有客户端(*)都是可读写的(rw),并且是异步方式来访问。 因为不设置其他参数, 客户端创建文件或目录时默认的属主和组就是nfsnobody,即使客户端使用的账号是root。


# exportfs -r 

 

Tip: -r Reexport all directories, synchronizing /var/lib/nfs/etab with /etc/exports. This option 

removes entries in /var/lib/nfs/etab which have been deleted from /etc/exports, and removes 

any entries from the kernel export table which are no longer valid. 

# showmount -e localhost 

Export list for localhost: 

/nfsdata * 

 

自己连接一下自己,测试一下。 

# mkdir /mnt/nfs 

# mount 127.0.0.1:/nfsdata/ /mnt/nfs 

查看 mount 的信息 

# mount 

/dev/mapper/VolGroup-lv_root on / type ext4 (rw) 

proc on /proc type proc (rw) 

sysfs on /sys type sysfs (rw) 

devpts on /dev/pts type devpts (rw,gid=5,mode=620) 

tmpfs on /dev/shm type tmpfs (rw) 

/dev/sda1 on /boot type ext4 (rw) 

none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw) 

/dev/sr0 on /mnt/cdrom type iso9660 (ro) 

sunrpc on /var/lib/nfs/rpc_pipefs type rpc_pipefs (rw) 

nfsd on /proc/fs/nfsd type nfsd (rw) 

127.0.0.1:/nfsdata/ on /mnt/nfs type nfs (rw,vers=4,addr=127.0.0.1,clientaddr=127.0.0.1) 

 

检查目录是否可以写入。 

# touch /mnt/nfs/testfile1.txt 

# ll /mnt/nfs/testfile1.txt  

-rw-r--r-- 1 nfsnobody nfsnobody 0 Jul 31 15:28 /mnt/nfs/testfile1.txt

注:如果以后直接在服务器上的共享目录创建文件或目录,要记得将属主和组设置为nfsnobody。否则客户端在访问时会出现“Permission denied”。

3.4. 配置 NFS 客户机 

NFS 客户机也需要安装 nfs-utils 包。 

# showmount -e 192.168.1.241 

Export list for 192.168.1.241: 

/nfsdata * 

[root@db1 ~]# mount 192.168.1.241:/nfsdata /mnt/nfs/ 

[root@db1 ~]# ls /mnt/nfs/ -l 

total 0 

-rw-r--r-- 1 nfsnobody nfsnobody 0 Jul 31 15:28 testfile1.txt 

[root@db1 ~]# echo test >> /mnt/nfs/testfile1.txt  

[root@db1 ~]# ls /mnt/nfs/testfile1.txt  

/mnt/nfs/testfile1.txt 

[root@db1 ~]# ls /mnt/nfs/testfile1.txt  -l 

-rw-r--r-- 1 nfsnobody nfsnobody 5 Jul 31 15:47 /mnt/nfs/testfile1.txt 

4.排错

4.1 启动NFS服务时出错

原因可能是rpcbind没有启动

# service rpcbind start

# service nfs start

4.2 权限出错

是文件系统的权限不足

# chmod a+w /nfsdata 



本文出自 “刘琼@天道酬勤” 博客,请务必保留此出处http://lqiong.blog.51cto.com/8170814/1549530

RedHat搭建NFS服务器