NFS网络文件系统

为什么要用NFS?

前端所有的应用服务器接收到用户上传的图片、文件、视频,都会统一放到后端的存储上。
共享存储的好处:方便数据的查找与取出,缺点:存储服务器压力大,坏了丢失全部数据。

NFS工作原理

NFS功能,有很多服务,每个服务都有自己的端口,并且经常变换。
客户端查找这些端口,就需要一个中间人---RPC服务(默认端口号111)。
工作流程:
1.启动RPC服务
2.启动NFS服务(同时向RPC服务注册启动的端口)
3.客户端向RPC请求NFS服务
4.RPC返回端口到客户端
5.客户端用返回的端口地址向NFS请求传输数据。

一、服务器A下操作(IP地址:192.168.2.21)

1、查看NFS安装情况:

rpm -qa nfs-utils rpcbind


(没有的话,用yum install nfs-utils rpcbind -y安装)
2、启动RPC:

systemctl start rpcbind   (service rpcbind start) 

开机自启动:

systemctl enable rpcbind   (service rpcbind enable)

看看有没有注册的端口:

rpcinfo -p 127.0.0.1


3、启动NFS:

systemctl start nfs(十以上版本sudo service nfs-server start)或者(systemctl start nfs-server)

再看注册的端口:

rpcinfo -p 127.0.0.1

发现多了很多
 
4、配置nfs (NFS配置文件/etc/exports)
创建目录/it/it/a文件作为共享目录和共享文件

mkdir /it
touch /it/a


编辑文件

vim /etc/exports
/it 192.168.2.0/24(rw,sync)


5、重启NFS

systemctl reload nfs或者exportfs -r

{
若出现exportfs: /home requires fsid= for NFS export

解决方法:
/home 192.167.253.0/24(fsid=0,rw,sync) //加入fsid=0参数就可
}
nfs默认用户nfsnobody

grep nfsno /etc/passwd


没有的话,自己创建

groupadd -g -f 65534 nfsnobody
useradd nfsnobody -u 65534 -g nfsnobody -s /sbin/nologin -M

6、授权

chown -R nfsnobody.nfsnobody /it

7、检查自己

showmount -e 192.168.2.21  (exportfs)

8、服务器本地挂载:

mount -t nfs 192.168.2.21:/it /mnt

本地测试成功

二、客户端B下操作(IP地址:192.168.2.25)

1、查看NFS安装情况:

rpm -qa nfs-utils rpcbind

(安装nfs-utils的目的是为了获得showmount命令)
2、启动RPC:

systemctl start rpcbind

开机自启动:

systemctl enable rpcbind
netstat -lntup|grep 111

3、查看NFS服务器提供的共享目录

showmount -e 192.168.2.21

{
i、若出现clnt_create: RPC: Program not registered:程序没有注册

说明:RPC服务器开启了,但NFS没有告诉RPC开启的服务端口
重启nfs

systemctl start nfs(十以上版本sudo service nfs-server start)或者(systemctl start nfs-server)

检查:rpcinfo -p 127.0.0.1(出现很多表明可以了)

ii、若出现:

去服务端(192.168.2.21)关闭防火墙

systemctl stop firewalld

}
4、挂载测试(将192.168.2.21挂载到192.168.2.25下)

mount -t nfs 192.168.2.21:/it /mnt

若出现:
 
则需要关掉防火墙:service firewalld stop

挂载成功。

三、NFS客户端开机自启动挂载

方法一:/etc/rc.local

chmod +x /etc/rc.d/rc.local

vim /etc/rc.local
在底部加上
/bin/mount -t nfs 192.168.109.132:/it /mnt
(将192.168.109.132挂载到192.168.109.131下) 

然后reboot重启
查看是否成功

 
方法二:放入vim /etc/fstab(有坑)

192.168.109.132:/it   /mnt   nfs  defaults      0 0

开启延迟满足的服务remote-fs.target(centos7)   netfs(centos6) 

systemctl start remote-fs.target
systemctl enable remote-fs.target
systemctl status remote-fs.target

  

(Debian)统信uos的NFS只是安装包不同

服务器安装包:

apt-get install nfs-kernel-server

客户端安装包:

apt install -y nfs-common 
dpkg -l nfs-kernel-server查看包

NFS配置-实现多服务器共享目录的更多相关文章

  1. 关于iis站点无法读取 服务器共享目录的问题

    也是权限问题,具体解决方法如下: 1. 找到该站点所在的应用程序池>>高级设置>>进程模型>>设置标志账号,如下图所示 2. 设置账号之后,找到该共享目录>& ...

  2. 在Jenkins上配置批处理删除远程共享目录7天以上的文件

    net use * /del /yes NET USE X: \\10.29.48.12\shares\Test password /user:DOMAIN1\account set AutoPath ...

  3. Linux和Linux之间共享目录

    1.Linux 服务器端NFS服务器的配置 以root身份登陆Linux服务器,编辑/etc目录下的共享目录配置文件exports,指定共享目录及权限等. 执行如下命令编辑文件/etc/exports ...

  4. NFS配置与安装

    安装 1 环境描述:    * 网络环境:                  NFS server: 192.168.102.47                  NFS client: 192.1 ...

  5. 嵌入式Linux之NFS配置

    NFS(Network File System) 1.RPC和rpcbind RPC(Remote Procedure Call)即远程过程调用,是分布式应用的基础,即允许计算机远程调用网络上其他计算 ...

  6. C# 客户端读取共享目录文件

    控制台应用程序 using System; using System.Collections.Generic; using System.Linq; using System.Text; using ...

  7. CentOS5.x、CentOS6.x 使用NFS及mount实现两台服务器间目录共享

    一.环境介绍: 服务器:centos 192.168.1.225 客户端:centos 192.168.1.226 二.安装: NFS的安装配置:centos 5 : portmap:实现RPC(协议 ...

  8. windows server 2008 R2 部署NFS,实现多台服务器间、客户端间的共享目录。

    如何通过Windows Server 2008 R2建立NFS存储服务? 通过Windows Server 2008 R2,我们可以很容易地将其作为一台NFS存储服务器,得到一个NFS软存储,轻松解决 ...

  9. 客户端挂载NFS服务器中的共享目录(用户后台上传图片与前台上传图片放在同一个服务器上)

    服务器端使用showmount命令查询NFS的共享状态 # showmount -e //默认查看自己共享的服务,前提是要DNS能解析自己,不然容易报错 # showmount -a //显示已经与客 ...

随机推荐

  1. spring 拦截器流程 HandlerInterceptor AsyncHandlerInterceptor HandlerInterceptorAdapter

    HandlerInterceptor源码 3种方法: preHandle:拦截于请求刚进入时,进行判断,需要boolean返回值,如果返回true将继续执行,如果返回false,将不进行执行.一般用于 ...

  2. Java操作Hadoop、Map、Reduce合成

    原始数据: Map阶段 1.每次读一行数据, 2.拆分每行数据, 3.每个单词碰到一次写个1 <0, "hello tom"> <10, "hello ...

  3. 交互式 .Net

    名词解析 1. 交互式 交互式是指输入代码后可直接运行该代码,然后持续输入运行代码. 2. 交互式 .Net .Net 是一种编译型语言,不像 python 这类的脚本型语言,可以边输入代码边运行结果 ...

  4. 23. Merge k Sorted Lists - LeetCode

    Question 23. Merge k Sorted Lists Solution 题目大意:合并链表数组(每个链表中的元素是有序的),要求合并后的链表也是有序的 思路:遍历链表数组,每次取最小节点 ...

  5. Linux下MySQL表名区分大小写

    问题:MySQL一个数据库的表名统一小写,在Windows上安装的MySQL没有问题,但是把数据库部署到Linux上,应用启动的时候报表不存在错误. 解决:修改my.cnf lower_case_ta ...

  6. Sqoop导入数据到mysql数据库报错:ERROR tool.ExportTool: Error during export: Export job failed!(已解决)

    问题描述: Container killed by the ApplicationMaster. Container killed on request. Exit code is 143 Conta ...

  7. Linux内网渗透

    Linux虽然没有域环境,但是当我们拿到一台Linux 系统权限,难道只进行一下提权,捕获一下敏感信息就结束了吗?显然不只是这样的.本片文章将从拿到一个Linux shell开始,介绍Linux内网渗 ...

  8. Unity中通过深度优先算法和广度优先算法打印游戏物体名

    前言:又是一个月没写博客了,每次下班都懒得写,觉得浪费时间.... 深度优先搜索和广度优先搜索的定义,网络上已经说的很清楚了,我也是看了网上的才懂的,所以就不在这里赘述了.今天讲解的实例,主要是通过自 ...

  9. 卸载windows安装ubuntu的完全指南

    卸载windows安装ubuntu的完全指南 新配置了一台深度学习服务器,但是预装系统为windows10,与需求不符.于是,自己动手安装ubuntu(18.04).此文为过程记录. 主要步骤: 准备 ...

  10. Typora使用手册(小白入门级)

    Typora软件的简单使用 1.简介 Typora是一款支持Markdown语法的文档编辑器      特点:功能强大.画面极简. 下载地址:https://typoraio.cn/ 2.基础设置 偏 ...