NFS全称是Network File System,网络文件系统。它可以通过网络实现文件共享。其结构图大概是这样的:

在机器E上开启NFS服务,机器ABCD都挂载NFS,这样可以实现机器ABCD共享文件。

由于文件共享的特性,NFS还被用作分布式系统的备份。比如Elasticsearch集群的备份需要用到NFS。

服务端

首先开启NFS服务端,在Ubuntu中的命令如下:

sudo apt-get update

sudo apt-get install nfs-kernel-server

然后我们建一个文件夹,用作共享目录:

sudo mkdir /var/nfs/general

这样建立的文件夹归属于root用户,那么客户端在使用的时候都需要root权限才能查看,因此我们需要修改一些文件夹归属:

sudo chown nobody:nogroup /var/nfs/general

然后需要修改一下NFS的配置,告诉NFS组件哪些文件夹需要导出。我们来编辑/etc/exports这个文件,其格式要求如下:

文件夹  客户端IP地址(权限选项1, 选项2, ...)

这里举个例子:

/var/nfs/general 127.0.0.1(rw,sync,no_subtree_check)

修改完成之后重启NFS服务端,命令如下:

sudo service nfs-kernel-server restart

这样我们就完成了服务端的搭建。

客户端

然后在另外一台机器上连接前面建立的NFS服务。首先要安装NFS客户端软件,在Ubuntu中的命令如下:

sudo apt-get update

sudo apt-get install nfs-common

然后建立一个共享目录:

sudo mkdir /nfs

然后把NFS挂载这个文件夹上:

sudo mount 127.0.0.1:/var/nfs/general /nfs

然后我们就可以在/nfs下访问共享目录啦。

最新文章

  1. 六个创建模式之单例模式(Singleton Pattern)
  2. 二模 (2) day2
  3. 剑指offer系列47---翻转单词顺序
  4. Project Euler 97 :Large non-Mersenne prime 非梅森大素数
  5. 为tomcat启用nio机制
  6. php加了命名空间没引入初始化文件:类的命名空间要与文件夹名一致namespace Business\Event;缺少了Event
  7. js插件zClip实现复制到剪贴板功能
  8. some idea for my personal page
  9. mysql 不能插入中文
  10. php中require、require_once、include、include_once类库重复引入效率问题详解
  11. Mybatis源码分析--关联表查询及延迟加载原理(二)
  12. 导出insert语句
  13. 在centos7下安装python3的步骤
  14. ReactiveX 学习笔记(24)使用 RxCpp + C++ REST SDK 调用 REST API
  15. js/jquery控制页面动态加载数据 滑动滚动条自动加载事件--转他人的
  16. 高性能NIO框架Netty-对象传输
  17. CFA
  18. 【hdu6035】 Colorful Tree dfs序
  19. python 函数私有方法
  20. XML External Entity attack

热门文章

  1. ucos实时操作系统学习笔记——内核结构和任务创建
  2. Web应用多账号系统设计及微信扫码登录实现
  3. 使用python实现短信PDU编码
  4. .Net使用RabbitMQ详解
  5. 设计模式(一):“穿越火线”中的“策略模式”(Strategy Pattern)
  6. SQL Server中提前找到隐式转换提升性能的办法
  7. c 进程和系统调用
  8. spring aop
  9. 读书笔记--SQL必知必会07--创建计算字段
  10. MongoDB分组汇总操作,及Spring data mongo的实现