搭建NFS文件共享系统

1、概述:

NFS(Network File System)意为网络文件系统,它最大的功能就是可以通过网络,让不同的机器不同的操作系统可以共享彼此的文件。简单的讲就是可以挂载远程主机的共享目录到本地,就像操作本地磁盘一样,非常方便的操作远程文件。本文将给大家讲解怎么在 CentOS 7上安装和配置 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/exportsvim /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查看是不是有效果了

搭建NFS文件共享系统

搭建NFS文件共享系统

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文件共享系统

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

搭建NFS文件共享系统

解决:

搭建NFS文件共享系统

搭建NFS文件共享系统

注意启动顺序

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

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

搭建NFS文件共享系统

缺少showmount命令

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

搭建NFS文件共享系统

搭建NFS文件共享系统

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

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

搭建NFS文件共享系统

分析:nfs服务器上

搭建NFS文件共享系统

客户端

搭建NFS文件共享系统

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

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

搭建NFS文件共享系统

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

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

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

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

搭建NFS文件共享系统

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

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

搭建NFS文件共享系统

Original: https://www.cnblogs.com/zcj-0928/p/15131779.html
Author: 相遂
Title: 搭建NFS文件共享系统

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/581771/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • Linux入门命令

    命令入门 命令提示符详解 find cut sort wc sed aws [root@localhost ~]# # /root [lilei@node1 ~]$ #/home/…

    Linux 2023年6月11日
    081
  • IOC Unity

    控制反转(Inversion of Control,缩写为IoC),是面向对象编程中的一种设计原则,可以用来减低计算机代码之间的耦合度。其中最常见的方式叫做依赖注入(Depende…

    Linux 2023年6月13日
    093
  • CentOS7为php7.2安装php-redis扩展

    先下载phpredis-develop 安装unzip、zip解压工具 解压后会多了个phpredis-develop的目录。进入目录 安装phpize模块 执行phpize 查找…

    Linux 2023年5月28日
    072
  • haproxy

    haproxy 一.haproxy简介 二.负载均衡 三.haproxy安装 1.yum安装 2.源码安装 2.1 配置文件解析 2.2时间格式 2.3 全局global 2.4 …

    Linux 2023年6月7日
    0102
  • cache和内存屏障

    1 cache简介 1.1 cache缓存映射规则 tag查看cache是否匹配,set index |tag |set index |block offset ||20-bit …

    Linux 2023年6月6日
    0101
  • Redis Cluster 介绍与使用

    Redis Cluster 功能特性 Redis 集群是分布式的redis 实现,具有以下特性: 1. 高可用性与可线性扩张到1000个节点 2. 数据自动路由到多个节点 3. 节…

    Linux 2023年5月28日
    096
  • Linux下 lsof 命令详解

    lsof 是 List Open File 的缩写, 它主要用来获取被进程打开文件的信息,我们都知道,在Linux中,一切皆文件,lsof命令可以查看所有已经打开了的文件,比如: …

    Linux 2023年6月13日
    088
  • Linux下无限期使用Navicat16

    原文链接:https://www.zhoubotong.site/post/79.htmllinux 下的数据库图形化工具比较好用的有dbeaver完全免费,相比navicat,我…

    Linux 2023年6月6日
    0137
  • 版本控制gitlab

    版本控制gitlab 版本控制gitlab 版本控制介绍 常用的版本控制工具: gitlab部署 gitlab网页界面的基本使用 使用命令行的方式进行上传文件 版本控制介绍 版本控…

    Linux 2023年6月6日
    0110
  • 版本控制gitlab

    版本控制gitlab 版本控制gitlab 什么是版本控制gitlab gitlab部署 什么是版本控制gitlab GitLab 是一个用于仓库管理系统的开源项目,使用Git作为…

    Linux 2023年6月6日
    097
  • 统计每个月兔子的总数—牛客网

    统计每个月兔子的总数_牛客题霸_牛客网 (nowcoder.com) #include using namespace std; int main() { //1 1 2 3 5 …

    Linux 2023年6月13日
    090
  • Flink 如何分流数据

    场景 分流方式 如何分流 使用Filter分流 使用Split分流 使用Side Output分流 场景 获取流数据的时候,通常需要根据所需把流拆分出其他多个流,根据不同的流再去作…

    Linux 2023年6月7日
    0122
  • Redis使用Swap,但系统可用内存充足

    最近生产环境遇到一个很奇怪的问题,系统内存32G,redis使用8G左右,剩余的内存都被系统cache使用,从表面上看系统可用内存有20G左右。但是系统运行过程中,redis时不时…

    Linux 2023年6月14日
    084
  • 自动化集成:Pipeline流水语法详解

    前言:该系列文章,围绕持续集成:Jenkins+Docker+K8S相关组件,实现自动化管理源码编译、打包、镜像构建、部署等操作; 本篇文章主要描述Pipeline流水线用法。 一…

    Linux 2023年5月27日
    0106
  • boot issue

    Q:生产过程中不小心把 boot文件删除了 ,或者升级kenerl时发现版本不兼容,需要回退,此时没有快照备份情况如何操作? A:boot 主要文件是内核和grub引导文件 1.进…

    Linux 2023年6月6日
    0106
  • 单例模式也能玩出花

    一、单例模式 (1)单例模式 (2)单例模式实现要点 (3)使用场景当频繁创建、销毁某个对象时,可以考虑单例模式。当创建对象消耗资源过多时,但又经常使用时,可以考虑单例模式。 (1…

    Linux 2023年6月14日
    081
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球