nfs网络文件系统服务实战

author author     2022-09-03     623

关键词:

NFS网络文件系统服务实战:

 

一、按要求搭建配置NFS服务前准备

准备三个服务器或虚拟机ABC配置NFS服务器:

要求:

  • NFS服务端A上共享/data/w_shared/data/r_shared两个文件目录,允许从NFS客户端BC上分别挂载共享目录后可实现从BC上只读/data/r_shared,可写/data/w_shared

  • NFS客户端B上的挂载点为/data/b_w(写),/data/b_r(读)

NFS客户端C上的挂载点为/data/w_你的名字英文(写),/data/r_你的名字英文(读)

3)NFS客户端B上的NFS可在挂载点目录创建任意文件,从C上可以删除这个创建的文件,反之也可以。

 

解答:

1.、系统环境准备

服务器系统

角色

IP

Centos64-130-server

NFS服务器A

192.168.221.130

Centos64-131-client

NFS客户端B

192.168.221.131

Centos58-133-client

NFS客户端C

192.168.221.133

 

主机名或规范:

nfs-A-C64  192.168.221.130

nfs-B-C64   192.168.221.131

nfs-C-C58  192.168.221.133

 

2.临时关闭selinuxiptables防火墙(将来工作中selinux可关,有外部ip的服务器要开iptables。)

关闭selinux

★修改配置文件需要重启机器:

修改/etc/selinux/config 文件

vim /etc/selinux/config

SELINUX=enforcing改为SELINUX=disabled

或者:

sed -i‘s#SELINUX=enforcing#SELINUX=disabled#g‘ /etc/selinux/config      #修改配置文件永久生效,但必须重启系统

 

★清空iptables

iptables -F    #清理防火墙规则

iptables -L    #查看防火墙规则

/etc/init.d/iptables save  #保存防火墙配置信息

 

 

3.查看系统环境:

分别使用cat /etc/redhat-release

        uname -n

        uname -a

 查看系统版本和内核版本,系统名等相关信息,

 

使用ifconfig分别查看ABC三台虚拟机的ip

 

二、NFS服务端配置

1.开启nfs 相关服务NFSrpcbind(C5.8portmap),并设置开机自启动

★安装rpcbind (C5.8 portmap)

[[email protected] ~]# yum install rpcbind  nfs-utils –y

★检查启动rpcbind

[[email protected] ~]# /etc/init.d/rpcbindstatus
rpcbind is stopped
[[email protected] ~]# /etc/init.d/rpcbindstart
Starting rpcbind:                                         [  OK  ]

★检查并启动nfs

[[email protected] ~]# /etc/init.d/nfs status
rpc.svcgssd is stopped
rpc.mountd is stopped
nfsd is stopped
rpc.rquotad is stopped
[[email protected] ~]# /etc/init.d/nfs start
Starting NFS services:                                     [  OK  ]
Starting NFS quotas:                                       [  OK  ]
Starting NFS mountd:                                       [  OK  ]
Stopping RPC idmapd:                                       [  OK  ]
Starting RPC idmapd:                                       [  OK  ]
Starting NFS daemon:                                       [  OK  ]

★设置rpcbindnfs开机自启动,

[[email protected] ~]# echo "#NFS sharedat mrxiong to 2017.6.5">>/etc/rc.local
[[email protected] ~]# echo "/etc/init.d/rpcbindstart">>/etc/rc.local       
[[email protected] ~]# echo "/etc/init.d/nfsstart">>/etc/rc.local     
[[email protected] ~]# tail -3 /etc/rc.local
#NFS shared at Mrxiong to 2017.6.5
/etc/init.d/rpcbind start
/etc/init.d/nfs start

注:rpcbind一定要先于nfs启动

 

2.统一所有服务器的nfs共享用户,一般是nfsnobodyuid65534。当然也可以自己创建一个NFS共享用户

[[email protected] ~]# grep 65534 /etc/passwd
nfsnobody:x:65534:65534:Anonymous NFSUser:/var/lib/nfs:/sbin/nologin
[[email protected] ~]# grep 65534 /etc/passwd
nfsnobody:x:65534:65534:Anonymous NFSUser:/var/lib/nfs:/sbin/nologin
[[email protected] ~]# grep 65534 /etc/passwd
nfsnobody:x:65534:65534:Anonymous NFSUser:/var/lib/nfs:/sbin/nologin

 

3.配置nfs服务端

 ★创建要共享的目录

 [[email protected]~]# mkdir -p /data/w_shared /data/r_shared

★根据需求授权指定权限(不要777,太大)

[[email protected] ~]# chown -R nfsnobody.nfsnobody /data/w_shared/data/r_shared
[[email protected] ~]# ls -ld /data/*
drwxr-xr-x 2 nfsnobody nfsnobody 4096 Jan 19 22:25 /data/r_shared
drwxr-xr-x 2 nfsnobody nfsnobody 4096 Jan 19 22:25 /data/w_shared

★配置NFS配置文件/etc/exports

[[email protected] ~]# echo "#NFS shared at dingjian 2017.6.5">>/etc/exports    
[[email protected] ~]# echo "/data/w_shared 192.168.221.1/24(rw,sync)">>/etc/exports
[[email protected] ~]# echo"/data/r_shared 192.168.221.1/24(ro,sync)">>/etc/exports [[email protected]~]# tail -3 /etc/exports
#NFS shared at dingjian 2017.6.5
/data/w_shared 192.168.221.1/24(rw,sync)
/data/r_shared 192.168.221.1/24(ro,sync)

★平滑重启reloadexportfs -rv

[[email protected] ~]# exportfs -rv
exporting 192.168.221.1/24:/data/r_shared
exporting 192.168.221.1/24:/data/w_shared

showmount -elocalhost 一下看配置有没有成功

[[email protected] ~]#  showmount -e localhost
Export list for localhost:
/data/r_shared 192.168.221.1/24
/data/w_shared 192.168.221.1/24

 

:配置客户端

.配置nfs-B-C64,客户端

★安装和开启rpcbind(C5.8portmap)服务,并加入到开机自启动rc.local (不需要开启nfs服务)

C64-B

[[email protected] ~]# yum install rpcbind -y
[[email protected] ~]# /etc/init.d/rpcbindstatus
rpcbind is stopped
[[email protected] ~]# /etc/init.d/rpcbindstart
Starting rpcbind:                                         [  OK  ]
[[email protected] ~]# /etc/init.d/rpcbindstatus
rpcbind (pid  1607) is running...

★创建挂载点,然后执行showmount命令查看挂载信息,如果不通可以使用ping iptelnet ip port来检查

C64-B

[[email protected] ~]# mkdir /data/b_w/data/b_r -p
[[email protected] ~]# ls -l /data
total 8
drwxr-xr-x. 2 root root 4096 Jan 19 22:36b_r
drwxr-xr-x. 2 root root 4096 Jan 19 22:36b_w
[[email protected] ~]# showmount -e192.168.221.130   ----->提示找不到这个命令
-bash: showmount: command not found
[[email protected] ~]# yum install showmount-y
[[email protected] ~]# showmount -e192.168.221.130
Export list for 192.168.221.130:
/data/r_shared 192.168.221.1/24
/data/w_shared 192.168.221.1/24

 

★通过mount命令执行挂载

C64-B

[[email protected] ~]#  mount -t nfs 192.168.221.130:/data/w_shared/data/b_w 
[[email protected] ~]#  mount -t nfs 192.168.221.130:/data/r_shared/data/b_r

★配置mount挂载命令使开机自启动

a./etc/rc.local里。缺点:偶尔开机挂载不上,工作中对其监控挂载点

[[email protected] b_w]# echo "mount -tnfs 192.168.221.130:/data/w_shared /data/b_w">>/etc/rc.local
[[email protected] b_w]# echo "mount-t nfs 192.168.221.130:/data/r_shared /data/b_r">>/etc/rc.local
[[email protected] b_w]# tail -2 /etc/rc.local
mount -t nfs 192.168.1.121:/data/w_shared /data/b_w
mount -t nfs 192.168.1.121:/data/r_shared /data/b_r

 

 

.配置nfs-C-C64,客户端

C58-C                 

[[email protected]~]# /etc/init.d/portmap status
portmap (pid 2656)is running...
[[email protected] ~]# mkdir /data/w_dingjian/data/r_dingjian -p
[[email protected] ~]# ls -l /data
total 8
drwxr-xr-x 2 root root 4096 Jan 19 22:38r_dingjian
drwxr-xr-x 2 root root 4096 Jan 19 22:38w_dingjian
[[email protected] ~]# showmount -e192.168.221.130
Export list for 192.168.221.130:
/data/r_shared 192.168.221.1/24
/data/w_shared 192.168.221.1/24

 

C58-C

[[email protected] ~]# mount -t nfs 192.168.221.130:/data/r_shared/data/r_dingjian
[[email protected] ~]# mount -t nfs 192.168.221.130:/data/w_shared/data/w_dingjian

 

★配置mount挂载命令使开机自启动

/etc/rc.local里。缺点:偶尔开机挂载不上,工作中对其监控挂载点

[[email protected] ~]# echo " mount -tnfs 192.168.221.130:/data/r_shared /data/r_dingjian
">>/etc/rc.local
[[email protected] ~]#echo " mount -t nfs192.168.221.130:/data/w_shared /data/w_dingjian
">>/etc/rc.local
[[email protected] ~]#  tail -2 /etc/rc.local
mount -t nfs 192.168.221.130:/data/r_shared/data/r_dingjian
mount -t nfs 192.168.221.130:/data/w_shared/data/w_dingjian

 

四、使用df-h或者cat /proc/mounts查看挂载情况

C64-B

[[email protected] ~]# df -h
Filesystem            Size  Used Avail Use% Mounted on
/dev/sda3              18G  1.4G  16G   9% /
tmpfs                 491M     0 491M   0% /dev/shm
/dev/sda1             190M   27M 153M  15% /boot
192.168.221.130:/data/w_shared
                       19G  1.4G  17G   8% /data/b_w
192.168.221.130:/data/r_shared
                       19G  1.4G  17G   8% /data/b_r

 


C58-C

[[email protected] ~]# df -h
Filesystem            Size  Used Avail Use% Mounted on
/dev/sda3              18G  2.1G  15G  13% /
/dev/sda1             198M   13M 176M   7% /boot
tmpfs                 499M     0 499M   0% /dev/shm
192.168.221.130:/data/r_shared
                       19G  1.4G  17G   8% /data/r_dingjian
192.168.221.130:/data/w_shared
                       19G  1.4G  17G   8% /data/w_dingjian

★根据要求做实际测试检查

分别对应要求来进行读写测试

 

如果把mount写到/etc/fstab里。缺点:NFS服务器端处不可用状态时,那么客户端开机可能会导致无法启动的风险。Fstab最后两列,要设置0 0。工作中对监控挂载点

 

个人建义使用/etc/rc.local

 

 

察看挂载后的状态。

[[email protected] ~]# mount |grep‘<nfs>‘
sunrpc on /var/lib/nfs/rpc_pipefs typerpc_pipefs (rw)
192.168.221.130:/data/w_shared on /data/b_wtype nfs (rw,vers=4,addr=192.168.221.130,clientaddr=192.168.221.131)
192.168.221.130:/data/r_shared on /data/b_rtype nfs (rw,vers=4,addr=192.168.221.130,clientaddr=192.168.221.131)

--------------------------------------------------------------------

可以看到已经挂到了当前的文件系统了。

 

 

 


本文出自 “Mr.Xiong`s 运维日志” 博客,请务必保留此出处http://mrxiong2017.blog.51cto.com/12559394/1932434

linuxnfs文件服务器实战

NFS是networkfilesystem的缩写,它最大的特点是可以通过网络,让不同的机器,不同的系统实现文件共享。NFS客户端可以将NFS服务器共享的目录挂载在本地的文件系统中,访问目录就如同访问自己本地目录一样。NFS工作原理首先服务... 查看详情

rsync+nfs+sersync实战案例(代码片段)

...s_log、access.log服务配置文件/etc/rsyncd.conf、/etc/exports...2.NFS网络文件系统,提供共享存储服务3.sersync提供实时同步服务 实验组合:1.rsync实验环境:rsync服务器rsync客户机实验需求:rsync服务器提供同步模块,rsync客户端可以通过推... 查看详情

nfs网络文件系统介绍

NFS网络文件系统介绍什么是NFS系统?NFS是NetworkFileSystem的缩写,它的主要功能是通过网络让不同的机器系统之间可以彼此共享文件和目录。NFS服务器可以允许NFS客户端,将远端NFS服务器端的共享目录,挂载到本地NFS客户端中。(... 查看详情

企业级nfs网络文件共享服务

...验:操作系统:CentOSrelease6.8(Final)虚拟机:VMware任务:NFS网络文件共享服务默认是没有安装NFS软件包,NFS主要功能是通过网络让不同的主机系统之间可以共享文件或目录。NFS网络文件系统很像Windows系统的网络共享、安全功能、网... 查看详情

网络文件系统(nfs)的使用

一。简介NFS--NetworkFileSystem,即网络文件系统,主要功能是让网络上的不同操作系统之间共享数据。远程服务器端共享出文件或目录,然后远羰共享出来的文件或目录就可通过挂载的方式挂接到本的不同操作系统上,最后本地系统... 查看详情

nfs服务和dhcp服务讲解

1.NFS服务端概述NFS,是NetworkFileSystem的简写,即网络文件系统。网络文件系统是FreeBSD支持的文件系统中的一种,也被称为NFS;NFS允许一个系统在网络上与他人共享目录和文件。模式:C/S模式端口:NFS是NetFileSystem的简写,即网络文... 查看详情

nfs(网络文件系统)

系统版本:CentOS7.X概念NFS(NetworkFileSystem)名为网络文件系统,是一种用于网络中主机与主机之间共享文件的一种服务。它把主机上要共享的目录通过文件系统的方式挂载到网络中的主机上,让网络中的主机访问共享目录就如同... 查看详情

nfs(网络文件系统)

NFS(网络文件系统)https://www.cnblogs.com/wahaha02/p/9559345.htmlLinux网络文件系统的实现与调试NFS协议NFS(网络文件系统)不是传统意义上的文件系统,而是访问远程文件系统的网络协议。整个NFS服务的TCP/IP协议栈如下图所示,NFS是应... 查看详情

红帽7nfs(网络文件系统)(代码片段)

NFS(网络文件系统)服务可以将远程Linux系统上的文件共享资源挂载到本地主机的目录上,从而使得本地主机(Linux客户端)基于TCP/IP协议,像使用本地主机上的资源那样读写远程Linux系统上的共享文件, RHEL7系统中默认已经... 查看详情

nfs网络文件系统原理与搭建

NFS工作流程图步骤1:先启动RPC服务步骤2:启动NFS服务(向RPC服务注册启动的端口)步骤3:客户向RPC请求NFS步骤4:RPC返回端口到客户步骤5:拿着地址端口请求传输数据服务搭建:将服务端/data挂载到/mnt目录下1:检查操作系统内核版... 查看详情

nfs网络文件系统服务配置验证及错误解决

NFS网络文件系统服务配置、验证及错误解决前期准备:    1.至少准备一台服务器(nfs-server)和一台客户机(nfs-client)。老表测试用的服务器端用的系统是ubuntu,客户机用的是CentOS6.5,所以有些地方操作不一样。 &nbs... 查看详情

nfs网络文件系统的搭建

 NFS网络文件系统的搭建什么是NFS网络文件系统?NFS(NetworkFileSystem)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源。在NFS的应用中,本地NFS的客户端应用可以透明地读... 查看详情

nfs网络文件系统配置

NFS网络文件系统配置 NFS简介NFS(NetworkFileSystem)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源。在NFS的应用中,本地NFS的客户端应用可以透明地读写位于远端NFS服务器... 查看详情

nfs网络文件系统(代码片段)

NFS(NetworkFileSystem)即网络文件系统,是FreeBSD支持的文件系统中的一种,他允许网络中的计算机之间通过TCP/IP网络共享资源。在NFS的应用中,本地NFS的客户端应用可以透明地读写位于远端NFS服务器上的文件,就像访问本地文件一... 查看详情

nfs网络文件系统详解(代码片段)

第1章NFS基本概述1.1什么是nfsNFS是NetworkFileSystem的缩写及网络文件系统。主要功能是通过局域网络让不同的主机系统之间可以共享文件或目录。NFS系统和Windows网络共享、网络驱动器类似,只不过windows用于局域网,NFS用于企业集群架... 查看详情

nfs网络共享文件服务搭建

一.NFS(networkfilesystem)1.概念:NFS(networkfilesystem)网络共享文件系统2.作用:类似于windows系统网络共享,但无法部署在windows中,适用于中小型企业共享部署,大型网站不适合(Moosefs,FASTdfs)windows网络共享FTP(linux),samba(linux),... 查看详情

网络文件共享服务-nfs(代码片段)

NFS服务NFS:NetworkFileSystem网络文件系统,基于内核的文件系统。Sun公司开发,通过使用NFS,用户和程序可以像访问本地文件一样访问远端系统上的文件,基于RPC(RemoteProcedureCallProtocol远程过程调用)实现RPC:采用C/S模式。客户机... 查看详情

nfs存储服务部署(上)

...1 NFS服务介绍1.1.1 什么是NFS?1.NFS——NetworkFileSystemt网络文件系统,叫称为网络共享文件系统2.作用:通过网络(一般为局域网)让不同主机系统之间可以共享文件3.NFS服务和winodws系统的网络共享很相似,但NFS无法部署在wind... 查看详情