p { margin-bottom: 0.25cm; line-height: 120% }
a:link { }

nfs是network file system的缩写,作用在于让不同的网络,不同的机器,不同的操作系统可以共享彼此的文件。也就是讲远程服务器共享的目录挂载到本地的文件系统中。远程目录看起来就像是自己的一个磁盘分区

NFS运行在SUN的RPC(Remote Procedure Call, 远程过程调用)基础上, RPC定义了一种与系统无关的方法来实现进程间通信. 由此, NFS server也可以看作是RPC server.

正因为NFS是一个RPC服务程序,
所以在使用它之前,
先要映射好端口——通过portmap设定.
比如:
某个NFS
client发起NFS服务请求时,
它需要先得到一个端口(port).
所以它先通过portmap得到port
number.

下面 来看下服务器测的安装方式:

1
首先nfs安装:apt-get
install nfs-kernel-server

2
安装完nfs-kernel-server后,系统会自动为我们安装好portmap(端口映射器)和nfs-common(客户端软件,用于测试)

3
配置共享目录,在/etc/exports文件中添加如下命令:意思分别是

/tmp:服务器需要共享的目录。

192.168.0.11
允许能访问服务器的IP地址。这里可以是具体的地址也可以是IP网络号。比如192.168.1.1/24。
也可以采用通配符*,表示允许所有能访问到server的主机来连接共享目录

rw:
共享权限。

rw:客户端拥有读写权限(ro:代码只有读权限)

sync:同步写入资料到内存和硬盘中

no_subtree_check:不检测子目录权限

root_squash:如果客户端使用root权限访问共享目录,则会被认为是匿名用户(权限缩小)

no_root_squash:如果客户端使用root权限访问共享目录,权限依旧为root

另外在这里我们还可以设定对共享目录文件访问的权限,这里需要用到setfacl命令。比如

setfacl
-m -u:zhf:rwx /tmp 就代表zhf的用户对这个目录下的文件具有rwx的权限

4
配置完成后,重启nfs-server服务/etc/init.d/nfs-kernel-server
restart。并执行showmount
-e就可以看到下面的挂载点。

root@zhf-virtual-machine:~#
showmount -e

/tmp
192.168.0.11(rw,no_root_squash)

5
服务器测安装apt-get
install nfs-common

6挂载服务器共享目录到本地

root@zhf-linux:/home#
mount -t nfs 192.168.0.9:/tmp /home/nfs/public

root@zhf-linux:/home#
df

Filesystem
1K-blocks Used Available Use% Mounted on

udev
1010832 0 1010832 0% /dev

tmpfs
205944 6528 199416 4% /run

/dev/sda1
238171776 11020944 215029284 5% /

tmpfs
1029712 30012 999700 3% /dev/shm

tmpfs
5120 4 5116 1% /run/lock

tmpfs
1029712 0 1029712 0% /sys/fs/cgroup

cgmfs
100 0 100 0% /run/cgmanager/fs

tmpfs
205944 56 205888 1% /run/user/1000

192.168.0.9:/tmp
19477248 1026432 17438464 6% /home/nfs/public

7
进入到/home/nfs/public就可以看到在192.168.0.9当中共享的文件

root@zhf-linux:/home/nfs/public#
ls -al

total
72

drwxrwxrwt
17 root root 4096 Oct 30 21:36 .

drwxr-xr-x
3 root root 4096 Oct 30 21:39 ..

-rw-------
1 zhf zhf 0 Oct 30 21:08 config-err-C8mCtt

drwxrwxrwt
2 root root 4096 Oct 30 21:06 .font-unix

drwxrwxrwt
2 root root 4096 Oct 30 21:08 .ICE-unix

drwx------
3 root root 4096 Oct 30 20:57
systemd-private-3b1f89764b29474681718903030213e2-colord.service-GtPb2r

drwx------
3 root root 4096 Oct 30 21:07
systemd-private-3b1f89764b29474681718903030213e2-rtkit-daemon.service-eMi74n

drwx------
3 root root 4096 Oct 30 21:06
systemd-private-3b1f89764b29474681718903030213e2-systemd-timesyncd.service-HMSDuI

drwxrwxrwt
2 root root 4096 Oct 30 21:06 .Test-unix

drwx------
9 root root 4096 Oct 30 21:09 ubuntu-release-upgrader-p9q1b5zo

-rw-rw-r--
1 zhf zhf 0 Oct 30 21:08 unity_support_test.0

drwxr-xr-x
2 root root 4096 Oct 30 21:09 upgrade-chroot-ano169rw

drwx------
2 root root 4096 Oct 30 21:09 upgrade-rw-699p254l

drwxrwxrwt
2 root root 4096 Oct 30 21:07 VMwareDnD

drwxr-xr-x
2 root root 4096 Oct 30 20:57 vmware-root

drwx------
2 root root 4096 Oct 30 21:07 vmware-root-2689209388

drwx------
2 zhf zhf 4096 Oct 30 21:08 vmware-zhf

-r--r--r--
1 root root 11 Oct 30 20:57 .X0-lock

drwxrwxrwt
2 root root 4096 Oct 30 20:57 .X11-unix

drwxrwxrwt
2 root root 4096 Oct 30 21:06 .XIM-unix

分钟使用该目录下的数据后,则客户端系统将会主动卸载/home/nfsfile/public.
autofs的配置很简单。下面来看下步骤:

1
建立主配置文件/etc/auto.master.设置如下:这个的意思是当要使用/home/nfsfile的数据时,会去读取/etc/auto.nfs的数据进行自动挂载

/home/nfsfile
/etc/auto.nfs

2
建立数据对应文件内/etc/auto.nfs的挂载信息与服务器对应的资源。下面的这个意思是当要使用/home/nfsfile/public的数据时,去自动挂载192.168.0.9的/tmp资源

public
-rw,bg,rsize=32768,wsize=32768 192.168.0.9:/tmp

3
去/home/nfsfile/public去实际查看的时候发现是自动挂载的

root@zhf-linux:/home/nfsfile/public#
mount | grep nfsfile

/etc/auto.nfs
on /home/nfsfile type autofs
(rw,relatime,fd=6,pgrp=5258,timeout=300,minproto=5,maxproto=5,indirect)

192.168.0.9:/tmp
on /home/nfsfile/public type nfs4
(rw,relatime,vers=4.0,rsize=32768,wsize=32768,namlen=255,hard,proto=tcp,port=0,timeo=600,retrans=2,sec=sys,clientaddr=192.168.0.11,local_lock=none,addr=192.168.0.9)

4
文件的挂载也出现了

root@zhf-linux:/home/nfsfile/public#
df /home/nfsfile/public

Filesystem
1K-blocks Used Available Use% Mounted on

192.168.0.9:/tmp
19477184 1018848 17445888 6% /home/nfsfile/public

一起来学linux:NFS服务器搭建的更多相关文章

  1. Linux NFS服务器搭建

    1.NFS:NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源.   在NFS的应用中,本地N ...

  2. Linux之我有你也有-共享平台NFS服务器搭建

    Linux之我有你也有-共享平台NFS服务器搭建 最近因工作需要,所以要搭一个共享的服务器用于存储.实现你有我有大家有的共享的和谐局面.想到了NFS-Network File System.接下来我便 ...

  3. Linux NFS服务器的安装与配置方法(图文详解)

    这篇文章主要介绍了Linux NFS服务器的安装与配置方法(图文详解),需要的朋友可以参考下(http://xb.xcjl0834.com) 一.NFS服务简介 NFS 是Network File S ...

  4. Linux NFS服务器的简明配置6.8

    Linux NFS服务器的简明配置6.8   Linux NFS服务器的简明配置 一.NFS服务简介 NFS 是Network File System的缩写,即网络文件系统.一种使用于分散式文件系统的 ...

  5. NFS服务器搭建-共享PC与ARM主板文件

    NFS服务器搭建-共享PC与ARM主板文件 在搭建好交叉编译环境之后需要实现目标板与宿主机的文件共享,在这里选择NFS,由于资料较多.需要注意的以下几点: 目标板与宿主机需要连接在同一个网段内. 宿主 ...

  6. Linux NFS服务器的安装与配置详解

    一.NFS服务简介 NFS是Network File System(网络文件系统).主要功能是通过网络让不同的服务器之间可以共享文件或者目录.NFS客户端一般是应用服务器(比如web,负载均衡等),可 ...

  7. Linux NFS服务器的安装与配置

    一.NFS服务简介 NFS 是Network File System的缩写,即网络文件系统.一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布.功能是通过网络让不同的机器.不同的操 ...

  8. (转)Linux NFS服务器的安装与配置

    转自:http://www.cnblogs.com/mchina/archive/2013/01/03/2840040.html 由于在6系列里面,portmap已经改名了 ,6系列需要使用 serv ...

  9. 【转载】Linux NFS服务器的安装与配置

    一.NFS服务简介 NFS 是Network File System的缩写,即网络文件系统.一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布.功能是通过网络让不同的机器.不同的操 ...

  10. NFS服务器搭建

    1. 安装nfs-kernel-server,然后编辑/etc/exports. /sambadata/nfsserver    10.0.0.0/255.255.255.0(fsid=0,all_s ...

随机推荐

  1. 升级Linux tar &&解决某用tar解压失败的tar包

    今天解压个文件,出来很多这样的: /bin/tar: Ignoring unknown extended header keyword `SCHILY.dev'/bin/tar: Ignoring u ...

  2. jdk版本切换

    安装1.6/1.7/1.8版本的jdk 保存jdk的安装目录下的文件 卸载所有jdk 将jdk各个版本拷贝到一个文件夹下 配置环境变量 因为安装之后系统会有注册表之类的文件,单纯的修改环境是不会修改成 ...

  3. BZOJ1059_矩阵游戏_KEY

    1059: [ZJOI2007]矩阵游戏 Time Limit: 10 Sec Memory Limit: 162 MB Description 小Q是一个非常聪明的孩子,除了国际象棋,他还很喜欢玩一 ...

  4. MVC发布网站

    首先Vs打开解决方案 在Global.asax中加入下列代码,否则会出现CSS JS失效 BundleTable.EnableOptimizations = false; 用户 'NT AUTHORI ...

  5. C#单例测试(懒汉式双锁保证线程安全)

    单例模式的概念 单例模式的意思就是只有一个实例.单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例.这个类称为单例类. 关键点: 这个类只有一个实例,这是最基本的 它必须自行创建 ...

  6. append、extend与insert的区别

    最近在自学Python语言,看到向列表增加更多数据时被append(),extend(),insert()方法绕晕了. 作为编程0基础的小白,觉得有必要自己再梳理一遍: 1.append()方法是指在 ...

  7. JS -- Variables As Properties

    Variables As Properties When you declare a global JavaScript variable, what you are actually doing i ...

  8. [js高手之路] html5 canvas动画教程 - 实时获取鼠标的当前坐标

    有了前面的canvas基础之后,现在开始就精彩了,后面写的canvas教程都是属于综合应用,前面已经写了常用的canvas基础知识,参考链接如下: [js高手之路] html5 canvas系列教程 ...

  9. Linux脚本入门(1)

    1. Linux 脚本编写基础1.1 语法基本介绍1.1.1 开头程序必须以下面的行开始(必须方在文件的第一行): #!/bin/sh 符号#!用来告诉系统它后面的参数是用来执行该文件的程序.在这个例 ...

  10. Python自学笔记-列表生成式(来自廖雪峰的官网Python3)

    感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看. 列表生成式 列 ...