Linux初学(十六)NFS文件共享

2024-04-06 21:52

本文主要是介绍Linux初学(十六)NFS文件共享,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、NFS

1.1 简介

NFS(Network File System,网络文件系统)是一种分布式文件系统协议,允许不同的计算机之间通过网络共享文件和目录。
NFS类似于类似于Windows文件共享

将Linux的一个目录共享到网络中,网络中的其他所有主机都可以使用这个共享目录中的文件

samba

文件共享

可以在Linux中通过samba共享一个目录,然后在Linux可以访问这个共享

nfs

网络磁盘

可以在一个Linux中发布一个共享磁盘/分区,然后在另一个Linux中可以挂载使用这个磁盘/分区

nfs是c/s架构

C/S架构程序

  •  客户端
  • 服务器端 

安装的组件

  • rpc (远程过程调用,Remote Procedure Call)是一种通信协议,允许在一个网络中的一台计算机(客户端)上调用另一台计算机(服务器)上的程序或方法,在Linux中,NFS使用RPC来实现客户端和服务器之间的通信。
  • nfs

1.2 安装配置NFS

  • 需要至少两个节点,都是Centos7系统
  • nfs-server:192.168.1.96
  • nfs-client:192.168.31.93

第一步:安装nfs的服务器端

# 关闭防火墙和selinux
[root@server1 ~]# systemctl stop firewalld
[root@server1 ~]# systemctl disable firewalld
[root@server1 ~]# setenforce 0
[root@server1 ~]# sed -i 's/=enf.*$/=disabled/g' /etc/selinux/config# 安装组件
[root@server1 ~]# yum install nfs-utils rpcbind -y
[root@server1 ~]# rpm -q nfs-utils rpcbind
nfs-utils-1.3.0-0.65.e17.x86_64
rpcbind-0.2.0-48.e17.x86_64# 启动rpc服务
[root@server1 ~]# systemctl start rpcbind
[root@server1 ~]# systemctl enable rpcbind
[root@server1 ~]# systemctl status rpcbind# 查看rpcbind中已经注册的端口信息
[root@server1 ~]# rpcinfo -p 192.168.31.100program vers proto   port  service100000    4   tcp    111  portmapper100000    3   tcp    111  portmapper100000    2   tcp    111  portmapper100000    4   udp    111  portmapper100000    3   udp    111  portmapper100000    2   udp    111  portmapper----------------------------------------------------------------------------------# 通过nfs共享目录/data1  /data2,需要通过修改配置文件来实现【/etc/exports】
# 修改nfs的配置文件,修改文件格式:
# 共享目录   NFS客户端地址1(参数1、参数2、...)   NFS客户端地址2(参数1、参数2、...)
# 参数rw ro[root@server1 ~]# cat /etc/exports
/data1 192.168.1.0/24(rw)
/data2 192.168.1.0/24(ro)# 创建共享目录
mkdir /data1 /data2# 准备几个测试文件【测试是否有读写权限】
[root@server1 ~]# cp /etc/passwd /etc/shadow /etc/inittab /data1/
[root@server1 ~]# chown -R nfsnobody.nfsnobody /data1/# 启动nfs服务
[root@server1 ~]# systemctl restart nfs
[root@server1 ~]# systemctl enable nfs
[root@server1 ~]# systemctl status nfs#查看当前服务器端的共享目录的情况
[root@server1 ~]#showmout -e "localhost"
Export list for localhost:
/data2 192.168.1.0/24
/data1 192.168.1.0/24

第二步:安装nfs的客户端

# 关闭防火墙和selinux
[root@client ~]# systemctl stop firewalld
[root@client ~]# systemctl disable firewall
[root@client ~]# setenforce 0
[root@client ~]# sed -i 's/=enf.*$/=disabled/g' /etc/selinux/config# 安装组件
[root@client ~]# yum install nfs-utils rpcbind -y
[root@client ~]# rpm -q nfs-utils rpcbind
nfs-utils-1.3.0-0.65.e17.x86_64
rpcbind-0.2.0-48.e17.x86_64# 启动rpc服务
[root@client ~]# systemctl start rpcbind
[root@client ~]# systemctl enable rpcbind
[root@client ~]# systemctl status rpcbind# 查看自己和服务端rpcbind中已经注册的端口信息
[root@client ~]# rpcinfo -p localhost
[root@client ~]# rpcinfo -p 192.168.1.96# 查看服务器端共享目录的情况
[root@client ~]# showmount -e "192.168.1.96"
/data2 192.168.1.0/24
/data1 192.168.1.0/24# 挂载nfs共享目录
[root@client ~}# mkdir /disk1
[root@client ~]# mount -t nfs 192.168.31.100:/data1 /disk1
[root@client ~]# mount | grep disk1
[root@client ~]# df -h | grep disk1

1.3 NFS权限

  • ro:只读
  • rw:读写
  • sync:同步
  • async:异步
  • hide:隐藏共享目录中的子目录
  • no_hide:不隐藏
  • secure:nfs使用1024以下的端口传递数据
  • insecure:nfs使用1024以上的端口传递数据
  • anonuid=N:指定nfs进程以哪个用户身份来运行【默认是以nfsnobody身份运行】
  • anongid=N:指定nfs进程以哪个用户组身份来运行【默认是以nfsnobody身份运行】
  • all_squash:将用户身份转化成指定的那个用户
  • root_squash:如果root身份来访问,将用户身份转化成指定的那个用户
  • root_squash:如果root身份来访问,不会将身份转化成指定的那个用户
nfs各个服务和程序的说明
1、nfsd(rpc.nfsd)它是NFS的本地守护进程,rpc.nfsd的主要功能是管理NFS客户端是能够登录nfs的服务器主机,其中还包括登录者的ID判别等
2、mountd(rpc.mountd)它是RPC安装守护进程,主要功能是管理NFS的文件系统。当客户端顺利地通过rpc.nfsd登录NFS服务器后,在使用NFS服务器所提供的文件钱,还必须通过文件使用权限的验证,rpc.mountd会读取NFS的配置文件/etc/exports来对比客户端的权限
3、rpcbindportmap的主要功能是进行端口映射工作。当客户端尝试连接并使用RPC服务器提供的服务(如NFS服务)时,portmap会将所管理的与服务对应的端口号提供给客户端,从而使客户端可以通过该端口向服务器请求服务。
4、rpc.lock(非必要)[在5才有]主要用来锁定文件,用于多客户端同时写入的情况
5、rpc.statd(非必要)NFS配置文件路径
1、/etc/exports
(man exports可以获取帮助)NFS服务主配置文件,默认内容为空,在这个文件中,每行可以共享一个文件
格式:[共享的目录][主机名1或IP1(参数1,参数2)] [主机名2或IP2(参数3,参数4)]当不指定参数时,nfs将使用默认选项。默认的共享选项是sync,ro,root_squash,no_delayeg: /home/share 192.168.1.122(rw,sync) *(ro)
主机表示方式单一主机    192.168.1.96整个网络    192.168.1.0/16192.168.*.*    (自行测试是否可以)单个域名    nfs.yshk.com    (好处是将来可以用在集群当中) 不常用整个域      *.yshk.com      不常用
常用参数:* ro        只读访问,使用较少* rw        读写访问* sync      所有数据在请求时写入共享(同步写入)* async     NFS在写入数据前可以相应请求(异步写入)secure      NFS通过1024以下的安全TCP/IP端口发送insecure    NFS通过1024以上的端口发送wdelay      如果多个用户要写入NFS目录,则归组写入(默认)no_wdelay   如果多个用户要写入NFS目录,则立即写入,当使用async时,无需此设置hide        在NFS共享目录中不共享其子目录no_hide     共享NFS目录的子目录subtree_check       如果共享/usr/bin子类的子目录时,强制NFS检查父目录的权限(默认)no_subtree_check    和上面相对,不检查父目录权限* all_squask        用来设置无论访问NFS Server共享目录的身份如何,它都将权限改为匿名用户,同时它的UID和GID会变成nfsnobody用户,在多个用户NFS客户端同时读写NFS Server的时候,这个参数很有用。(所有访问用户都映射为匿名用户或用户组)下面又all_squash的案例* no_all_squash    保留共享文件的UID和GID(默认),访问用户先与本机用户匹配,匹配失败后再映射为匿名用户或用户组* root_squash       如果访问共享目录的用户是root身份,则转换为匿名用户(默认)* no_root)squas     root用户具有根目录的完全管理访问权限* anonuid=xxx       指定NFS服务器/etc/passwd文件中匿名用户的UID* anongid=xxx       指定NFS服务器/etc/passwd文件中匿名用户的GID相关命令:cat /var/liv/nfs/etab查看发布权限 showmount -e 192.168.1.122 在服务器端查看192.168.1.122的共享文件
2、/usr/sbin/exportsfs这是NFS服务的管理命令,使用service nfs reload相当于/usr/sbin/exportsfs -rv,也就是说这个exports可以读取nfs的配置文件,另外,其实这个exports可以直接共享目录而无需配置文件3、/usr/sbin/showmount常在客户端,查看nfs配置及其配置结果的命令通常需要在服务端和客户端执行此命令在服务器端查看nfs共享情况
[root@yshk ~]# showmount -e localhost在客户端查看nfs共享情况
[root@yshk ~]# showmount -e localhost4、/var/lib/etab,这是状态信息文件,可以显示当前共享文件的权限等信息,其中包括在/etc/exports中设置的默认权限5、/var/lilb/rmtab,这是状态信息文件,可以显示当前在使用共享分区的远程主机信息
[root@yshk ~]# cat /var/lib/nfs/rmtab
192.168.1.93:/data:0x00000036、/var/lib/xtab,这个文件停用了

这篇关于Linux初学(十六)NFS文件共享的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/880919

相关文章

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

Linux环境变量&&进程地址空间详解

《Linux环境变量&&进程地址空间详解》本文介绍了Linux环境变量、命令行参数、进程地址空间以及Linux内核进程调度队列的相关知识,环境变量是系统运行环境的参数,命令行参数用于传递给程序的参数,... 目录一、初步认识环境变量1.1常见的环境变量1.2环境变量的基本概念二、命令行参数2.1通过命令编程

Linux之进程状态&&进程优先级详解

《Linux之进程状态&&进程优先级详解》文章介绍了操作系统中进程的状态,包括运行状态、阻塞状态和挂起状态,并详细解释了Linux下进程的具体状态及其管理,此外,文章还讨论了进程的优先级、查看和修改进... 目录一、操作系统的进程状态1.1运行状态1.2阻塞状态1.3挂起二、linux下具体的状态三、进程的

Linux编译器--gcc/g++使用方式

《Linux编译器--gcc/g++使用方式》文章主要介绍了C/C++程序的编译过程,包括预编译、编译、汇编和链接四个阶段,并详细解释了每个阶段的作用和具体操作,同时,还介绍了调试和发布版本的概念... 目录一、预编译指令1.1预处理功能1.2指令1.3问题扩展二、编译(生成汇编)三、汇编(生成二进制机器语

Rsnapshot怎么用? 基于Rsync的强大Linux备份工具使用指南

《Rsnapshot怎么用?基于Rsync的强大Linux备份工具使用指南》Rsnapshot不仅可以备份本地文件,还能通过SSH备份远程文件,接下来详细介绍如何安装、配置和使用Rsnaps... Rsnapshot 是一款开源的文件系统快照工具。它结合了 Rsync 和 SSH 的能力,可以帮助你在 li

Linux部署jar包过程

《Linux部署jar包过程》文章介绍了在Linux系统上部署Java(jar)包时需要注意的几个关键点,包括统一JDK版本、添加打包插件、修改数据库密码以及正确执行jar包的方法... 目录linux部署jar包1.统一jdk版本2.打包插件依赖3.修改密码4.执行jar包总结Linux部署jar包部署

mysqld_multi在Linux服务器上运行多个MySQL实例

《mysqld_multi在Linux服务器上运行多个MySQL实例》在Linux系统上使用mysqld_multi来启动和管理多个MySQL实例是一种常见的做法,这种方式允许你在同一台机器上运行多个... 目录1. 安装mysql2. 配置文件示例配置文件3. 创建数据目录4. 启动和管理实例启动所有实例

Linux内存泄露的原因排查和解决方案(内存管理方法)

《Linux内存泄露的原因排查和解决方案(内存管理方法)》文章主要介绍了运维团队在Linux处理LB服务内存暴涨、内存报警问题的过程,从发现问题、排查原因到制定解决方案,并从中学习了Linux内存管理... 目录一、问题二、排查过程三、解决方案四、内存管理方法1)linux内存寻址2)Linux分页机制3)

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

虚拟机与物理机的文件共享方式

《虚拟机与物理机的文件共享方式》文章介绍了如何在KaliLinux虚拟机中实现物理机文件夹的直接挂载,以便在虚拟机中方便地读取和使用物理机上的文件,通过设置和配置,可以实现临时挂载和永久挂载,并提供... 目录虚拟机与物理机的文件共享1 虚拟机设置2 验证Kali下分享文件夹功能是否启用3 创建挂载目录4