nfs服务器--RHCE

一,简介

NFS(Network File System,网络文件系统)是FreeBSD支持的文件系统中的一种,它允许网络中的计 算机(不同的计算机、不同的操作系统)之间通过TCP/IP网络共享资源,主要在unix系列操作系统上使 用。在NFS的应用中,本地NFS的客户端应用可以透明地读写位于远端NFS服务器上的文件,就像访问本地文件一样。

NFS服务器可以让PC将网络中的NFS服务器共享的目录挂载到本地端的文件系统中,而在本地端的系统 中看来,那个远程主机的目录就好像是自己的一个磁盘分区一样。

由于NFS支持的功能比较多,而不同的功能都会使用不同的程序来启动,每启动一个功能就会启用一些 端口来传输数据,因此NFS的功能所对应的端口并不固定,而是随机取用一些未被使用的小于1024的端 口用于传输。但如此一来就会产生客户端连接服务器的问题,因为客户端需要知道服务器端的相关端口才能够连接。

此时就需要RPC(Remote Procedure Call,远程过程调用)的服务。由于当服务器在启动NFS时会随机 选取数个端口号,并主动向RPC注册,所以RPC知道每个NFS功能所对应的端口号,RPC将端口号通知给 客户端,让客户端可以连接到正确的端口上去。RPC采用固定端口号port 111来监听客户端的需求并向 客户端响应正确的端口号。

注:在启动NFS之前,要先启动RPC,否则NFS会无法向RPC注册。另外,RPC若重新启动,原来注册的 数据会消失不见,因此RPC重启后,它管理的所有服务都需要重新启动以重新向RPC注册。

二,nfs配置

复制代码
#基本配置 
[root@localhost ~]# yum install rpcbind
 [root@localhost ~]# yum install nfs-utils
 /etc/exports 主配置文件(文件不一定存在)
/usr/sbin/showmount 该命令主要用在client端。这个命令可以查看NFS共享出来的目录资源

#服务端(192.168.168.128)
[root@server data]# mkdir  /data
[root@server data]# cat /etc/exports
 /data  192.168.168.140(rw)
 #共享目录  主机名(权限)
#可以使用完整的IP或者是网络号,例如172.24.8.128或172.24.8.0/24或者
172.24.8.128/255.255.255.0;也可以使用*表示所有主机
[root@server data]# chmod o+w  /data/
[root@server data]# systemctl disable firewalld --now
[root@server data]# getenforce
Enforcing
[root@server data]# setenforce  0
[root@server data]# systemctl restart nfs-server
[root@server data]# showmount -e 192.168.168.128
Export list for 192.168.168.128:
/data 192.168.168.140

权限相关参数可以写多个,多个参数之间用逗号隔开,具体相关参数说明如下:

复制代码
#客户端(192.168.168.140)
[root@client ~]# showmount -e 192.168.168.128
 Export list for 192.168.168.128:
 /data 192.168.168.140
 [root@client ~]# mkdir -p /nfsclient/client-data/
 [root@client ~]# mount  192.168.168.128:/data  /nfsclient/client-data/
 [root@client ~]# df -h
 Filesystem               Size  Used Avail Use% Mounted on
 devtmpfs                 898M     0  898M   0% /dev
 tmpfs                    910M     0  910M   0% /dev/shm
 tmpfs                    910M  9.6M  901M   2% /run
 tmpfs                    910M     0  910M   0% /sys/fs/cgroup
 /dev/mapper/centos-root   37G  1.8G   36G   5% /
 /dev/sda1               1014M  150M  865M  15% /boot
 tmpfs                    182M     0  182M   0% /run/user/0
 192.168.168.128:/data     40G  6.2G   34G  16% /nfsclient/client-data

三.配置autofs自动挂载

在一般NFS文件系统的使用过程中,如果客户端要使用服务端所提供的文件系统,可以在 /etc/rc.d/rc.local 中设置开机时自动挂载( /etc/rc.d/rc.local 文件中写入的命令,在每次启动系统用户 登录之前都会执行一次);也可以在登录系统后手动利用mount来挂载。

复制代码
 #客户端配置autofs
 [root@client ~]# yum install autofs -y
 [root@client ~]# grep suibian /etc/auto.master
 /client  /etc/auto.suibian
 #本地端目录  具体挂载配置文件
 [root@client ~]# cat /etc/auto.suibian
 upload 192.168.168.128:/nfs/upload
 #本地端子目录 挂载参数 服务器:服务器对应目录
 [root@client ~]# systemctl restart autofs
 #触发自动挂载
 [root@client ~]# cd /client
 [root@client ~]# cd upload
相关推荐
chenzfp5 分钟前
【运维】鲲鹏麒麟V10 操作系统aarch64自制OpenSSH 9.8p1 rpm包 ssh漏洞修复
运维·ssh
TG_yunshuguoji11 分钟前
亚马逊云代理商:AWS怎么通过加密实现数据保护目标?
服务器·云计算·aws
61900833613 分钟前
linux 安装jdk
java·linux·运维
可涵不会debug17 分钟前
UU远程深度测评:重构远程控制体验的“无套路”标杆
运维·服务器
峰顶听歌的鲸鱼33 分钟前
1.云计算与服务器基础
运维·服务器·笔记·云计算·学习方法
IDOlaoluo44 分钟前
dotnet-sdk-5.0.400-linux-x64.tar.gz 安装教程(Linux 手动安装 .NET 5.0.400 SDK 步骤)
运维·服务器
2501_915918411 小时前
iOS 混淆与 IPA 加固一页式行动手册(多工具组合实战 源码成品运维闭环)
android·运维·ios·小程序·uni-app·iphone·webview
扶尔魔ocy1 小时前
【DIY】RS232串口监听头制作
运维·rs232
迎風吹頭髮1 小时前
Linux服务器编程实践60-双向管道:socketpair函数的实现与应用场景
linux·运维·服务器
AORO20252 小时前
航运、应急、工业适用,AORO P1100三防平板引领行业数字化变革
运维·服务器·网络·智能手机·电脑·信息与通信