nfs服务器

一、简介

NFS服务器可以让PC将网络中的NFS服务器共享的目录挂载到本地端的文件系统中,而在本地端的系统 中看来,那个远程主机的目录就好像是自己的一个磁盘分区一样。 由于NFS支持的功能比较多,而不同的功能都会使用不同的程序来启动,每启动一个功能就会启用一些 端口来传输数据,因此NFS的功能所对应的端口并不固定,而是随机取用一些未被使用的小于1024的端 口用于传输。但如此一来就会产生客户端连接服务器的问题,因为客户端需要知道服务器端的相关端口 才能够连接。

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

二、配置

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

#服务端
[root@Server ~]# mkdir /data
[root@Server ~]# vim /etc/exports
/data 192.168.48.140(rw)
 
#共享目录 主机名(权限)
#权限相关参数可以写多个,多个参数之间用逗号隔开,具体相关参数说明如下:
复制代码
[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 ~]# systemctl restart nfs-server.service
[root@Server ~]# showmount -e 192.168.48.142
Export list for 192.168.48.142:
/data 192.168.48.140

#客户端
[root@Client yum.repos.d]# systemctl restart nfs-server.service
[root@Client yum.repos.d]# showmount -e 192.168.48.142
Export list for 192.168.48.142:
/data 192.168.48.140
[root@Client /]# mkdir /guazhai
[root@Client /]# ll -d /guazhai
drwxr-xrwx. 2 root root 6 10月 27 16:14 /guazhai

实验效果

复制代码
#服务端
[root@Server ~]# cd /data
[root@Server data]# ll
总用量 0
-rw-r--r--. 1 nobody nobody 0 10月 27 16:22 file1
#客户端
[root@Client /]# cd /guazhai
[root@Client guazhai]# ll
总用量 0
[root@Client guazhai]# touch file1
[root@Client guazhai]# ll file1
-rw-r--r--. 1 nobody nobody 0 10月 27 16:22 file1
[root@Client guazhai]# df -h
df: /data: 过旧的文件控柄
文件系统               容量  已用  可用 已用% 挂载点
devtmpfs               4.0M     0  4.0M    0% /dev
tmpfs                  867M     0  867M    0% /dev/shm
tmpfs                  347M   11M  336M    4% /run
/dev/mapper/rhel-root   17G  5.6G   12G   33% /
/dev/nvme0n1p1         960M  299M  662M   32% /boot
tmpfs                  174M  104K  174M    1% /run/user/1000
/dev/sr1               9.9G  9.9G     0  100% /run/media/red1/RHEL-9-3-0-BaseOS-x86_641
/dev/sr0               9.9G  9.9G     0  100% /run/media/red1/RHEL-9-3-0-BaseOS-x86_64

三、配置autofs自动挂载

复制代码
#客户端配置autofs
[root@client ~]# yum install autofs -y
[root@Client guazhai]# vim /etc/auto.master
[root@Client guazhai]# vim /etc/auto.suibian
[root@Client guazhai]# grep suibian /etc/auto.m
auto.master    auto.master.d/ auto.misc
[root@Client guazhai]# grep suibian /etc/auto.master
/nfsclient /etc/auto.suibian
[root@Client guazhai]# cat /etc/auto.suibian
gongxiang 192.168.48.142:/data
#本地端子目录 挂载参数 服务器:服务器对应目录
[root@client ~]# systemctl restart autofs
#触发自动挂载
[root@client ~]# cd /client
[root@client ~]# cd upload
相关推荐
七夜zippoe3 小时前
CANN Runtime任务描述序列化与持久化源码深度解码
大数据·运维·服务器·cann
盟接之桥3 小时前
盟接之桥说制造:引流品 × 利润品,全球电商平台高效产品组合策略(供讨论)
大数据·linux·服务器·网络·人工智能·制造
会员源码网4 小时前
理财源码开发:单语言深耕还是多语言融合?看完这篇不踩坑
网络·个人开发
米羊1214 小时前
已有安全措施确认(上)
大数据·网络
Fcy6485 小时前
Linux下 进程(一)(冯诺依曼体系、操作系统、进程基本概念与基本操作)
linux·运维·服务器·进程
袁袁袁袁满5 小时前
Linux怎么查看最新下载的文件
linux·运维·服务器
代码游侠5 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法
主机哥哥5 小时前
阿里云OpenClaw部署全攻略,五种方案助你快速部署!
服务器·阿里云·负载均衡
Harvey9035 小时前
通过 Helm 部署 Nginx 应用的完整标准化步骤
linux·运维·nginx·k8s
ManThink Technology5 小时前
如何使用EBHelper 简化EdgeBus的代码编写?
java·前端·网络