NFS概述:

NFS,是Network File System的简写,即网络文件系统。网络文件系统是FreeBSD支持的文件系统中的一种,也被称为NFS. NFS允许一个系统在网络上与他人共享目录和文件。通过使用NFS,用户和程序可以像访问本地文件一样访问远端系统上的文件。

安装NFS(在sishen_63上面)

[root@sishen_63 ~]# yum install -y nfs-utils

启动NFS

[root@sishen_63 ~]# service nfs start

Starting NFS services:                                     [  OK  ]

Starting NFS quotas:                                       [  OK  ]

Starting NFS mountd:                                       [  OK  ]

Starting NFS daemon:                                       [  OK  ]

Starting RPC idmapd:                                       [  OK  ]

查看端口

[root@sishen_63 ~]# netstat -antup | grep 2049

tcp        0      0 0.0.0.0:2049                0.0.0.0:*                   LISTEN      -                  

tcp        0      0 :::2049                     :::*                        LISTEN      -                  

udp        0      0 0.0.0.0:2049                0.0.0.0:*                               -                  

udp        0      0 :::2049                     :::*                                    -

设置开机自动起的话使用chkconfig nfs on这条命令。

设置测试目录

[root@sishen_63 ~]# vim /etc/exports

/tmp *(rw)

[root@sishen_63 ~]# service nfs restart

客户端查看(在sishen_64上)

测试客户端访问权限

[root@sishen_64 opt]# touch sishen_64.txt  注意看红色字体

[root@sishen_64 opt]# ll

total 70636

drwx------ 2 root      root          4096 Sep 12 18:07 keyring-GhLJxt

drwx------ 2 gdm       gdm           4096 Sep 12 18:07 orbit-gdm

drwx------ 2 root      root          4096 Sep 12 18:11 orbit-root

drwx------ 2 root      root          4096 Sep 12 18:07 pulse-GF9xIQtH3K7r

drwx------ 2 gdm       gdm           4096 Sep 12 18:08 pulse-KrvunjvNzMZC

-rw-r--r-- 1 nfsnobody nfsnobody        0 Sep 12 20:11 sishen_64.txt

-rw-r--r-- 1 root      root         10795 Sep 12 18:06 vgauthsvclog.txt.0

drwx------ 2 root      root          4096 Sep 12 15:47 virtual-root.GbNb3n

drwx------ 2 root      root          4096 Sep 12 18:07 virtual-root.GMsPxq

drwx------ 2 root      root          4096 Sep 12 15:04 virtual-root.moiJHi

drwxrwxrwt 2 root      root          4096 Jun 19  2016 VMwareDnD

drwx------ 2 root      root          4096 Sep 12 18:07 vmware-root

-r--r--r-- 1 root      root      72270857 Jun 20  2016 VMwareTools-10.0.5-3228253.tar.gz

其他测试

创建共享目录

[root@sishen_63 ~]# mkdir -p /share/{aa,bb,cc,dd,ee,ff}

[root@sishen_63 ~]# ll /share/

total 24

drwxr-xr-x 2 root root 4096 Sep 12 22:58 aa

drwxr-xr-x 2 root root 4096 Sep 12 22:58 bb

drwxr-xr-x 2 root root 4096 Sep 12 22:58 cc

drwxr-xr-x 2 root root 4096 Sep 12 22:58 dd

drwxr-xr-x 2 root root 4096 Sep 12 22:58 ee

drwxr-xr-x 2 root root 4096 Sep 12 23:00 ff

修改配置文件

/tmp *(rw)  

/share/aa  *(rw,no_root_squash)  

/share/bb  192.168.1.0/24(rw,sync)

/share/cc  192.168.1.64(ro)

/share/dd  *.baidu.com(rw,all_squash,anonuid=500,anongid=500)

/share/ee  192.168.2.0/24(async) 192.168.3.0/24(rw)

/share/ff  *(rw,root_squash)

sync/async  数据同步写入硬盘/不同步写入在内存中缓存

root_squash 压制root,如果用root登录,使其身份自动切换成nfsnobody

no_root_squash 不压制root ,如果是root登录nfs,身份就是root

更改/share目录权限

[root@sishen_63 ~]# ll -d /share/

drwxr-xr-x 8 root root 4096 Sep 12 23:00 /share/

[root@sishen_63 ~]# chmod 777 -R /share/

[root@sishen_63 ~]# ll -d /share/

drwxrwxrwx 8 root root 4096 Sep 12 23:00 /share/

重启nfs服务

[root@sishen_63 ~]# service nfs restart

客户端验证

[root@sishen_64 ~]# showmount -e 192.168.1.63

Export list for 192.168.1.63:

/share/ff *

/share/aa *

/tmp      *

/share/dd *.baidu.com

/share/ee 192.168.3.0/24,192.168.2.0/24

/share/cc 192.168.1.64

/share/bb 192.168.1.0/24

被拒绝了,没有权限

去服务端更改配置文件,然后重启nfs服务后再来测试

修改内容

将 /share/dd  *.baidu.com(rw,all_squash,anonuid=500,anongid=500)

改为  /share/dd  *(rw,all_squash,anonuid=500,anongid=500)

挂载成功!

测试文件权限

挂载其他目录,ee目录由于服务端限制,所以挂载会出错。

查看挂载目录

添加普通用户

使用root和sishen用户登录,创建并对比文件权限

因为aa目录不压制root用户,所以aa.txt的所有者还是root,但是注意普通用户是nobody。

切换到cc目录下,使用sishen用户创建文件失败,因为该目录为只读

切换到root用户去创建,仍然失败,因为该目录权限对所有用户为只读

切换到ff目录下,分别使用root和sishen用户创建文件,并查看文件权限

因为ff目录压制root,所以root身份映射成nfsnobody。

配置自动挂载

需要在客户端编辑/etc/fstab文件,内容格式为:

192.168.1.63:/share/aa  /share/aa               nfs     defaults        0 0

保存退出,重启客户端操作系统验证。

AutoNFS

[root@sishen_63 ~]# yum install -y autofs

客户端创建测试共享测试目录

[root@sishen_64 ~]# mkdir /tmp/{a,root_squash,no_root_squash,all_squash}

服务端修改配置文件,大约在第7行左右,/misc下面添加如下内容

[root@sishen_63 ~]# vim /etc/auto.master

/tmp/a    /etc/auto.nfs --timeout=60

/tmp/all_squash /etc/auto.nfs   --time=60

/tmp/root_squash /etc/auto.nfs  --time=60

/tmp/no_root_squash /etc/auto.nfs --time=60

注意:红色字体是挂载到本地时目录的名字

[root@sishen_63 ~]# vim /etc/auto.nfs

/tmp/a          -fstype=nfs     192.168.1.64:/tmp/a

root_squash     -fstype=nfs     192.168.1.64:/tmp/root_squash

no_root_squash  -fstype=nfs     192.168.1.64:/tmp/no_root_squash

all_squash      -fstype=nfs     192.168.1.64:/tmp/all_squash

注意:红色字体名字自己定义即可,没有特殊要求

服务端重启autofs服务

[root@sishen_63 ~]# service autofs restart

Stopping automount:                                        [  OK  ]

Starting automount:                                        [  OK  ]

首次访问共享目录,需要手动切进去,之后就不需要了,如下

[root@sishen_63 ~]# cd /tmp/a

[root@sishen_63 a]# touch sishen_63.test  #创建文件失败,因为没有给权限

touch: cannot touch `sishen_63.test': Permission denied

[root@sishen_63 ~]# cd /tmp/all_squash

[root@sishen_63 all_squash]# cd ..

[root@sishen_63 tmp]# cd root_squash

为了验证共享目录是sishen_64上的,我们可以停掉autofs服务,查看。

[root@sishen_63 tmp]# service autofs stop

Stopping automount:                                        [  OK  ]

[root@sishen_63 tmp]# cd a

-bash: cd: a: No such file or directory

[root@sishen_63 tmp]# cd root_squash

-bash: cd: root_squash: No such file or directory

由此可见,以上4个目录均是sishen_64上的。

到此,搞一小段,之后会做出其他相应的服务。欢迎各位读者大佬批评指正~~~

NFS与AutoNFS实例的更多相关文章

  1. 嵌入式环境搭建之NFS

    嵌入式环境搭建之NFS Author:tiger-johnTime:2013-08-04mail:jibo.tiger@gmail.comBlog:http://blog.csdn.net/tiger ...

  2. day10、nfs+rsync全网备份及实时同步

    题目要求 注意:博主使用的系统为: [root@web01 ~]# uname -a Linux web01 2.6.32-696.el6.x86_64 #1 SMP Tue Mar 21 19:29 ...

  3. NFS服务的配置与应用

    一.NFS服务概述 NFS(Network File System),即网络文件系统,是使不同计算机之间能够通过网络进行文件共享的一种网络协议,多用于Linux/Unix网络系统中. 一台NFS服务器 ...

  4. NFS (网络文件系统)

    NFS (网络文件系统) https://www.cnblogs.com/wahaha02/p/9559345.html Linux网络文件系统的实现与调试 NFS协议 NFS (网络文件系统)不是传 ...

  5. 【集群实战】NFS网络文件共享服务

    1. NFS介绍 1.1 什么是NFS? NFS是Network File System的缩写,中文意思是网络文件系统. 它的主要功能是通过网络(一般是局域网)让不同的主机系统之间可以共享文件或目录. ...

  6. linux添加开机自启动脚本示例详解

    linux下(以RedHat为范本)添加开机自启动脚本有两种方法,先来简单的; 一.在/etc/rc.local中添加如果不想将脚本粘来粘去,或创建链接什么的,则:step1. 先修改好脚本,使其所有 ...

  7. linux开机启动

    开机过程指的是从打开计算机电源直到LINUX显示用户登录画面的全过程.分析LINUX开机过程也是深入了解LINUX核心工作原理的一个很好的途径. 启动第一步--加载BIOS 当你打开计算机电源,计算机 ...

  8. linux 开机自动启动脚本方法

    通过现场对这次天津iptv demo项目的调测.对iptv这套系统有了更好的认识和理解.由于iptv本身需要安装许多服务.而现场实施中有没有把这些需要启动服务的脚本加入到开 机自动运行中.如果服务器重 ...

  9. Linux网络文件系统的实现与调试

    NFS协议 NFS (网络文件系统)不是传统意义上的文件系统,而是访问远程文件系统的网络协议.整个NFS服务的TCP/IP协议栈如下图所示,NFS是应用层协议,表示层是XDR,会话层是RPC,传输层同 ...

随机推荐

  1. I2S总线协议理解

    I2S总线 Inter IC Sound总线又称集成电路内置音频总线. I2S对数字音频设备之间的音频数据传输而制定的一种总线标准. 采用了沿独立的导线传输时钟与数据信号的设计,通过将数据和时钟信号分 ...

  2. Couldn't connect to host, port: smtp.163.com, 25; timeout -1;

    运行出现以下报错: Couldn't connect to host, port: smtp.163.com, 25; timeout -1; 也要设置端口 spring.mail.port=25

  3. bzoj 2301 [HAOI2011]Problem b(莫比乌斯反演+分块优化)

    题意:对于给出的n个询问,每次求有多少个数对(x,y),满足a≤x≤b,c≤y≤d,且gcd(x,y) = k,gcd(x,y)函数为x和y的最大公约数. 1≤n≤50000,1≤a≤b≤50000, ...

  4. linux防火墙过滤规则

    一.linux防火墙基础 防火墙分为硬件防火墙和软件防火墙. 1.概述 linux 防火墙体系主要工作在网络层,针对TCP/IP数据包实施过滤和限制,属于典型的包过滤防火墙. 包过滤机制:netfil ...

  5. codeforces 414C C. Mashmokh and Reverse Operation(归并排序求逆序对)

    题目链接: C. Mashmokh and Reverse Operation time limit per test 4 seconds memory limit per test 512 mega ...

  6. #ifndef <标识> #define <标识> #endif

    头件的中的#ifndef,这是一个很关键的东西.比如你有两个C文件,这两个C文件都include了同一个头文件.而编译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突. 还是把 ...

  7. CreateThread创建线程 互斥量锁

    HANDLE CreateThread( LPSECURITY_ATTRIBUTES lpThreadAttributes,//SD:线程安全相关的属性,常置为NULL SIZE_T dwStackS ...

  8. wxPython学习笔记1

    wxpython介绍: wxPython 是 Python 语言的一套优秀的 GUI 图形库,允许 Python 程序员很方便的创建完整的.功能键全的  GUI 用户界面. wxPython 是作为优 ...

  9. 如何升级xcode 中的cocos2dx 到v2.2.2以上版本

    每次升级cocos2dx版本都觉得不知道怎么弄才行. 这次升级到v2.2.2版本又花了我不少时间.因此在这里分享一下,以后也有地方可以查询. 1. 到http://cocos2d-x.org/ 下载最 ...

  10. Harbor安装部署--基于 Docker Distribution 的企业级 Registry 服务

    harbor简介 Harbor 是一个企业级 Registry 服务.它对开源的 Docker Registry 服务进行了扩展,添加了更多企业用户需要的功能.Harbor 被设计用于部署一套组织内部 ...