nfs实现


实现环境

[root@backup ~]# cat /etc/redhat-release 

CentOS release 6.7 (Final)

[root@backup ~]# uname -r                

2.6.32-573.el6.x86_64

[root@backup ~]# uname -i

x86_64

一 安装;

yum install nfs-utils rpcbind

#因为nfs开启后应用的端口是随机的,所以需要借助rpc将nfs当前应用的端口告知客户端。

#客户端同样需要下载rpc和nfs,但是客户端不需要开启nfs。

#若客户端未安装nfs

[root@nfs01 backup]# rpm -ql nfs-utils|grep bin

/sbin/mount.nfs

/sbin/mount.nfs4

/sbin/nfs_cache_getent

/sbin/rpc.statd

/sbin/umount.nfs

/sbin/umount.nfs4

/usr/sbin/exportfs

/usr/sbin/mountstats

/usr/sbin/nfsidmap

/usr/sbin/nfsiostat

/usr/sbin/nfsstat

/usr/sbin/rpc.gssd

/usr/sbin/rpc.idmapd

/usr/sbin/rpc.mountd

/usr/sbin/rpc.nfsd

/usr/sbin/rpc.svcgssd

/usr/sbin/rpcdebug

/usr/sbin/showmount

/usr/sbin/sm-notify

/usr/sbin/start-statd

可能出现在客户端没法挂载的情况。

二 配置相关文件;

vim /etc/exports

/data 172.16.1.41(rw,sync)

/etc/exports文件内容格式:

<输出目录> [客户端1 选项(访问权限,用户映射,其他)] [客户端2 选项(访问权限,用户映射,其他)]  

可以用man exports查看文件内容格式; 

#其中扩好中选项;可以用来优化nfs

下面列一些下关的选项参数;

设置输出目录只读: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服务器也不检查其父目录的权限,这样可以提高效率;

  

三  查看是否可以挂载

showmount -e localhost

四 更改共享目录的属主和属组

chown nobody.nobody /data

#远程登陆nfs默认的能录用户为nobody,在此结合服务端配置参数理解。

自此服务端配置完成。  

五 客户端挂载;

先用showmount -e 172.16.1.31服务端IP   查看挂载信息。

六 挂载;

mount -t nfs 172.16.1.31:/data  /mnt

#在此客户端也有相应的nfs挂咋参数和mount -o 相关参数可以配置,可以优化nfs。

七 查看挂载信息、

命令df -h /mount/cat /proc/mounts 

#在此最好使用后面两个命令,因为当服务端挂了,df -h就会卡住。



作者知识有限,望给位给予指正;谢谢。

你可能感兴趣的:(nfs,showmount)