1、概述:

NFS(Network File System)意为网络文件系统,它最大的功能就是可以通过网络,让不同的机器不同的操作系统可以共享彼此的文件。简单的讲就是可以挂载远程主机的共享目录到本地,就像操作本地磁盘一样,非常方便的操作远程文件。本文将给大家讲解怎么在CentOS7上安装和配置NFS服务器

1.1准备

条件有限,我们用虚拟机做测试,分别做NFS服务器客户端,配置如下:

VMware16.0

Centos虚拟机两台

NFS服务器ip:192.168.0.77。

客户端ip:192.168.0.83。

我们要实现的目标是:在NFS服务器上共享一个目录,在客户端上可以直接操作NFS服务器上的这个共享目录下的文件。

 

 

2、NFS服务器配置

2.1 安装NFS服务

首先使用yum安装nfs服务:

yum -y install rpcbind nfs-utils

2.1.1 创建共享目录

服务器上创建共享目录,并设置权限。

mkdir /data/share/

chmod 755 -R /data/share/

 

2.2 配置NFS

nfs的配置文件是 /etc/exportsvi/etc/exports后在配置文件中加入一行:

/data/share/ 192.168.0.83/22(rw,no_root_squash,no_all_squash,sync)

这行代码的意思是把共享目录/data/share/共享给192.168.0.83这个客户端

注:客户端ip后需加上端口号,否则无法操作

ip,后面括号里的内容是权限参数,其中:

rw 表示设置目录可读写。

sync 表示数据会同步写入到内存和硬盘中,相反 rsync 表示数据会先暂存于内存中,而非直接写入到硬盘中。

no_root_squash NFS客户端连接服务端时如果使用的是root的话,那么对服务端分享的目录来说,也拥有root权限。

no_all_squash 不论NFS客户端连接服务端时使用什么用户,对服务端分享的目录来说都不会拥有匿名用户权限。

如果有多个共享目录配置,则使用多行,一行一个配置。保存好配置文件后,需要执行以下命令使配置立即生效:

exportfs -r

2.3设置防火墙

如果你的系统没有开启防火墙,那么此步骤可以省略。

NFS的防火墙除了固定的port111、2049外,还有其他服务如rpc.mounted等开启的不固定的端口,因此我们需要设置NFS服务的端口配置文件。

vi/etc/sysconfig/nfs文件,将下列内容的注释去掉,如果没有则添加:

RQUOTAD_PORT=1001

LOCKD_TCPPORT=30001

LOCKD_UDPPORT=30002

MOUNTD_PORT=1002

保存好后,将端口加入到防火墙允许策略中。执行:

firewall-cmd --zone=public --add-port=111/tcp --add-port=111/udp --add-port=2049/tcp --add-port=2049/udp --add-port=1001/tcp --add-port=1001/udp --add-port=1002/tcp --add-port=1002/udp --add-port=30001/tcp --add-port=30002/udp --permanent

firewall-cmd --reload

注:若只为测试操作,也可直接关闭防火墙

#sudo systemctl status firewalld。  //查看防火墙状态

查看后,看到active(running)就意味着防火墙打开了。

#sudo systemctl stop firewalld  //关闭防火墙

关闭后再查看是否关闭成功,如果看到inactive(dead)就意味着防火墙关闭了。

实际生产中不建议这么做

2.4启动服务

按顺序启动rpcbind和nfs服务:(此顺序不能颠倒,否则后续会报错)

systemctl start rpcbind

systemctl start nfs(centos7)

systemctl start nfs-server(centos8)

加入开机启动:

systemctl enable rpcbind

systemctl enable nfs(centos7)

systemctl enable nfs-server(centos8)

nfs服务启动后,可以使用命令 rpcinfo -p 查看端口是否生效。

我们可以使用 showmount 命令来查看服务端(本机)是否可连接:

[root@localhost ~]# showmount -e localhost

Export list for localhost:

/data/share 192.168.0.83/22

出现上面结果表明NFS服务端配置正常。

3、客户端配置

3.1安装rpcbind服务

客户端只需要安装rpcbind服务即可,一般无需安装nfs或开启nfs服务。

yum -y install rpcbind

(注:若后续操作无法使用showmount命令则此步骤建议使用命令

yum -y install rpcbind nfs-utils因为有些虚拟机可能会内置showmount命令,同时若安装nfs,需确保与nfs服务器端版本一致

3.2挂载远程nfs文件系统

查看服务端已共享的目录:

[root@localhost ~]# showmount -e 192.168.0.77

Export list for 192.168.0.77:

/data/share 192.168.0.83/22

建立挂载目录,执行挂载命令:

mkdir -p /mnt/share

mount -t nfs 192.168.0.77:/data/share /mnt/share/ -o nolock,nfsvers=3,vers=3

如果不加 -onolock,nfsvers=3 则在挂载目录下的文件属主和组都是nobody,如果指定nfsvers=3则显示root。

如果要解除挂载,可执行命令:

umount /mnt/share

3.3开机自动挂载

如果按本文上面的部分配置好,NFS即部署好了,但是如果你重启客户端系统,发现不能随机器一起挂载,需要再次手动操作挂载,这样操作比较麻烦,因此我们需要设置开机自动挂载。我们不要把挂载项写到/etc/fstab文件中,因为开机时先挂载本机磁盘再启动网络,而NFS是需要网络启动后才能挂载的,所以我们把挂载命令写入到/etc/rc.d/rc.local文件中即可。

[root@localhost ~]# vim /etc/rc.d/rc.local

#在文件最后添加一行:

mount -t nfs 192.168.11.34:/data/share /mnt/share/ -o nolock,nfsvers=3,vers=3

保存并重启机器看看。

3.4测试验证

查看挂载结果,在客户端输入 df -h

文件系统 容量 已用 可用 已用% 挂载点

devtmpfs                  895M     0  895M    0% /dev

tmpfs                     910M     0  910M    0% /dev/shm

tmpfs                     910M   11M  900M    2% /run

tmpfs                     910M     0  910M    0% /sys/fs/cgroup

/dev/sda3                  23G  4.9G   18G   22% /

/dev/sda1                 297M  163M  134M   55% /boot

tmpfs                     182M   28K  182M    1% /run/user/1000

tmpfs                     182M     0  182M    0% /run/user/0

192.168.0.77:/data/share   36G   22G   15G   61% /mnt/share

看到最后一行,就说明已经挂载成功了。接下来就可以在客户端上进入目录/mnt/share下,新建/删除文件,然后在服务端的目录/data/share查看是不是有效果了

4、错误分析:

4.1错误一:exportfs -r时出错

exportfs:  192.168.0.252:/data/share: Function not implemented

解决:

注意在vi /etc/exports时

加入的一行配置应该包括ip地址的端口号

/data/share/ 192.168.0.252/22(rw,no_root_squash,no_all_squash,sync)

否则会报错

4.2错误二:showmount -e localhost时报错

clnt_create: RPC: Program not registered

原因:很可能是因为nfs未正常启动

解决:

注意启动顺序

#先启动rpcbind,不然无法启动nfs

4.3错误三:在客户端测试时,发现无法使用showmount命令

缺少showmount命令

解决:CentOS安装某个缺少的命令比如showmount,ifconfig

4.4错误四:requested NFS version or transport protocol is not supported

需求的nfs版本或传输协议不支持

分析:nfs服务器上

客户端

原因:之前因为服务器上没有showmount命令,因此安装了nfs-utils.x86_64导致服务器和客户端的nfs版本不一致

解决:先卸载客户端的nfs-utils.x86_64

然后重新安装同一版本的nfs

解决方法:这边建议安装centos8的虚拟机,因为centos7,8的yum内核版本相差太大,直接用yum安装yum -y install rpcbind nfs-utils

时nfs的版本相差两个等级,且无法回退版本,导致mount挂载时无法操作

4.5错误五:mount -t挂载时,显示connection refused

解决方法:nfsvers=3,vers=3;或nfsvers=2,vers=2,

以及确定格式mount -t (nfs 服务端IP) 192.168.0.77:挂载目录是否无误

搭建NFS文件共享的更多相关文章

  1. RHEL6.4 NFS文件共享服务搭建

    NFS文件共享服务 1 实验方案 使用2台RHEL6.4虚拟机,其中一台作为NFS共享服务器(192.168.100.1).另外一台作为测试用的NFS客户机(192.168.100.2) 2.实现 2 ...

  2. Linux 搭建NFS文件服务器实现文件共享

    我们接着玩Linux,O(∩_∩)O哈哈~ 1.什么是nfs NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP ...

  3. <实训|第五天>通过搭建NFS,FTP实现共享文件附Vim脚本游戏

    先说个事情:我周末是不更新这个系列教程的,不过其他内容的会更新,我周末就整理这一周的各种内容到我的微信公众号中,提供给大家! 期待已久的linux运维.oracle"培训班"终于开 ...

  4. Ubuntu 12.04.2搭建nfs服务器

    1.安装nfs 服务器(192.168.0.1) apt-get install nfs-kernel-server 2.修改nfs配置文件: vim /etc/exports 在exports文件中 ...

  5. NFS文件系统及搭建NFS共享服务

    一.什么是文件系统? 文件系统是对一个存储设备上的数据和元数据进行组织的一种机制.文件系统是在一个磁盘(包括光盘.软盘.闪盘及其它存储设备)或分区上组织文件方式方法,常见文件系统如ext2.ext3. ...

  6. Kerberos认证原理及基于Kerberos认证的NFS文件共享

    目录 Kerberos认证原理 简介 client访问server过程 一.Authentication Service Exchange (AS Exchange) 二.Ticket Grantin ...

  7. CentOS6.5下搭建NFS文件服务器

    本文参考这里 CentOS下搭建NFS服务器总结 环境介绍: 1. 服务器: 192.168.0.100 2. 客户机: 192.168.0.101 安装软件包: 服务器和客户机都要安装nfs 和 r ...

  8. 使用docker搭建nfs实现容器间共享文件

    首先介绍下今天的两个主角:nfs和docker nfs 是什么 NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TC ...

  9. Ubentu搭建nfs服务器

    搭建nfs服务    功能:完成在线调试程序,远程挂载,在线调试    NFS(Network FileSystem,网络文件系统)是由SUN公司发展,并于1984年推出的技术,用于不同机器,不同操作 ...

随机推荐

  1. 关于Word转Markdown的工具Writage安装及使用

    简介 Writage是为希望开始编写结构良好的文档,没有时间或不想深入了解 Markdown 语法的详细信息,或者更愿意使用 Word 作为文本编辑器的每个人设计的 下载并安装 安装包地址:https ...

  2. Linux下Rsyslog日志远程集中式管理

    Rsyslog简介 Rsyslog的全称是 rocket-fast system for log,它提供了高性能,高安全功能和模块化设计.rsyslog能够接受从各种各样的来源,将其输入,输出的结果到 ...

  3. 使用A Star 算法实现自动寻路详解

    @ 目录 1.什么是A Start算法 2.A Star算法的原理和流程 2.1 前提 2.1.1 从起点开始扩散的节点 2.1.2 最短距离计算公式:F = G + H 2.1.3 欧几里得距离计算 ...

  4. ubuntu 18.4LTS 安装12.1.6赛门铁克防病毒系统

    创建/tools/ 文件夹,并将需要的软件包上传到该目录下 # mkdir -p /tools/ && cd /tools/ # tar -xzvf chang.tar.gz # cd ...

  5. Tiling 简单递推+大数

    Tiling c[0]=1,c[1]=1,c[2]=3;   c[n]=c[n-1]+c[n-2]*2;   0<=n<=250.   大数加法 java  time  :313ms 1 ...

  6. Prometheus(一):Web服务环境监控

    写在前面 现每个后端的同学的日常都在跟服务(接口)打交道,维护老的比较大单体应用.按业务拆得相对比较细的新服务.无论企业内部用的,面向用户的前端的服务.流量大的有流量小的,有重要的有不那么重要的. 但 ...

  7. Spring:Spring项目多接口实现类报错找不到指定类

    spring可以通过applicationContext.xml进行配置接口实现类 applicationContext.xml中可以添加如下配置: 在application.properties中添 ...

  8. 为什么使用 LSTM 训练速度远大于 SimpleRNN?

    今天试验 TensorFlow 2.x , Keras 的 SimpleRNN 和 LSTM,发现同样的输入.同样的超参数设置.同样的参数规模,LSTM 的训练时长竟然远少于 SimpleRNN. 模 ...

  9. idea本地调式tomcat源码

    前言 上篇文章中一直没搞定的tomcat源码调试终于搞明白了,p神的代码审计星球里竟然有,真的好b( ̄▽ ̄)d ,写一下过程,还有p神没提到的小坑 准备阶段 1.去官网下东西:https://tomc ...

  10. 【网络IO系列】IO的五种模型,BIO、NIO、AIO、IO多路复用、 信号驱动IO

    前言 在上一篇文章中,我们了解了操作系统中内核程序和用户程序之间的区别和联系,还提到了内核空间和用户空间,当我们需要读取一条数据的时候,首先需要发请求告诉内核,我需要什么数据,等内核准备好数据之后 , ...