NFS配置文件权限参数说明(/etc/exports)

1、rw  :表示可读写权限。

2、ro  :表示只读权限。

3、sync  :请求或写入数据时,数据同步写入到NFS Server的硬盘后才返回。(优点:数据安全不会丢。缺点:性能比启用该参数要差)。

4、async  :写入时数据会先写到内存缓冲区,只到硬盘有空档才会再写入磁盘,这样可以提升写入效率!风险:若服务器宕机或不正常关机,会损失

       缓冲区中未写入磁盘的数据(解决办法:服务器主板电池或加UPS不间断电源)。

5、no_root_squash  :访问NFS Server共享目录的用户如果是root的话,它对该共享目录具有root权限,这个配置原本是为无盘客户端准备的。用户应避免使用。

6、root_squash  :如果访问NFS Server共享目录的用户是root,则它的权限将压缩成匿名用户,同时它的UID和GID通常会变成nfsnobody账号身份。

7、all_squash  :不管访问NFS Server共享目录的用户身份如何,它的权限都将被压缩成匿名用户,同时它的UID和GID都会变成nfsnobody账号身份。在

         早期多个NFS客户端同时读写NFS Server数据时,这个参数很有用。

         在生产中配置NFS的重要技巧:1、确保所有客户端服务器对NFS共享目录具备相同的用户访问权限

                        a、all_squash把所有客户端都压缩成固定的匿名用户(UID相同)。

                        b、就是anonuid,anongid指定的UID和GID的用户。

                       2、所有的客户端和服务端都需要有一个相同的GID和UID用户,即nfsnobody(UID必须相同)。

anonuid  :参数以anon*开头即指anonymous匿名用户,这个用户的UID设置值通常为nfsnobody的UID值,当然也可以自行设置这个UID值。

       但是UID必须存在于/etc/passwd中。在多NFS Clients时,如果Web Server共享一个NFS目录,通过这个参数可以使得不同的NFS

       Clients写入的数据对所有NFS Clients保持统一的用户权限,即为配置的匿名UID对应的用户权限,这个参数很有用,一般默认即可。

anongid  :同anonuid,区别就是把uid(用户id)换成gid(组id)。

一、部署NFS服务所需用到的软件

  nfs-utils:NFS服务的全程序,包括rpc.nfsd、rpc.mountd这两个daemons和相关文档说明,以及执行命令文件等。

    rpcbind:Centos.x下面RPC的主程序。NFS可视为一个rpc程序,在互动任何一个RPC程序之前,需要做好端口和功能的对应映射工作,这个映射工作就是由RPCBIND服务来完成的。因此,在提供NFS服务之前必须先启动RPCBIND服务。

二、搭建服务

  ***服务端***

  1、安装常用到的软件(yum install lrzsz nmap tree dos2unix nc -y)

  2、安装NFS(yum install nfs-utils rpcbind)

  3、启用rpcbind服务(/etc/init.d/rpcbind start){先},centos7 (systemctl start rpcbind.service),设置开机启动(systemctl enable rpcbind.service)

   4、查看rpcinfo服务信息(rpcinfo -p localhost)

   5、启用nfs服务(/etc/init.d/nfs start){后}

   6、创建/data目录(mkdir /data -p),再设置/data属于nfsnobody目录(chown -R nfsnobody.nfsnobody /data)

   7、设置允许接入的网址和目录(vim /etc/exports)

    注意:1、rw与sync的分隔符是逗号不是点

       2、rpc先启动nfs后启动,顺序不对会导致服务器报错 

   8、检查rpcbind服务和nfs服务是否启动(/etc/init.d/rpcbind status,/etc/init.d/nfs status)

   9、确保有注册的端口(rpcinfo -p localhost)

  10、平滑重启(/etc/init.d/nfs reload),检查是否部署成功(showmount -e 172.16.1.100),centos7(systemctl restart nfs.service)、设置开机启动(systemctl enable nfs.service)

    ***有目标文件表示部署成功***

   扩展:查看服务端配置参数(cat /var/lib/nfs/etab)

      查看已安装的软件和未安装的软件(yum grouplist)

   ***客户端***

  1、开启rpcbind服务(/etc/init.d/rpcbind start

  2、查看rpcbind服务(/etc/init.d/rpcbind status)

  3、设置开机启动( chkconfig rpcbind on)

  4、查看启动设置(chkconfig --list rpcbind)

  5、检查部署是否成功(showmount -e 172.16.1.100),或(telnet 172.16.1.100)

   6、挂载(mount -t nfs 172.16.1.100:/data /mnt)

  7、查看inode(df -h),有以下挂载点则成功

  8、开机自动挂载(echo "mount -t nfs 172.16.1.100:/data /mnt" >>/etc/rc.local)或将172.16.1.100:/oapath /oapath nfs defaults 0 0)写入/etc/fstab/

注:nfs服务有时候会挂掉!需要重启!但是还没找到很好解决的方案

NFS共享存储优化小结:

      cat >>/etc/sysctl.conf <<EOF

   > net.core.wmem_default=8388608

   > net.core.rmem_default=8388608
   > net.core.rmem_max=16777216
   > net.core.wmem_max=16777216
   
> EOF

/proc/sys/net/core/rmem_default:该文件制定接收套接字缓冲区大小,默认为124928。(以字节为单位)

/proc/sys/net/core/rmem_max:该文件制定接收套接字缓冲区大小的最大值,默认为124928。(以字节为单位)

/proc/sys/net/core/wmem_default:该文件制定发送套接字缓冲区大小,默认为124928。(以字节为单位)

/proc/sys/net/core/wmem_max:该文件指定缓冲区大小的最大值,默认为124928。(以字节为单位)

1、如果卸载的时候提示"umount:/mnt:device is busy",需要退出挂载目录在运行卸载,如果是NFS Server宕机了,则需要强制卸载(umount -lf /mnt)。

2、大型网站NFS网络文件系统的替代软件为分布式文件系统Moosefs(mfs)、GlusterFs、FastDFS。

Llinux,NFS服务搭建(文件共享)的更多相关文章

  1. Linux下网络文件系统NFS服务搭建易错点总结

    一.环境准备: 1 [root@czh ~]# cat /etc/redhat-release 2 CentOS release 6.7 (Final) 3 [root@czh ~]# uname - ...

  2. NFS服务搭建与配置

    启动NFS SERVER之前,首先要启动RPC服务(CentOS5.8下为portmap服务,CentOS6.6下为rpcbind服务,下同),否则NFS SERVER就无法向RPC服务注册了.另外, ...

  3. NFS服务搭建使用

    需求:由于线上业务有一些数据存在了Redis数据库和mysql数据库中了,导致了数据较大迁移起来比较麻烦,所以准备搭建NFS来做WEB的共享磁盘,存储这些数据. 服务端搭建: 查看本机关于nfs的包 ...

  4. linux服务搭建----NFS服务搭建

    nfs  服务     //配置脚本         /etc/exports     //服务器  发布目录     1> 确定需要发布的目录(想要共享的目录)     例如:      想发 ...

  5. Linux之NFS服务搭建及autofs服务搭建

    NFS 网络文件系统,英文Network File System(NFS),是由SUN公司研制的UNIX表示层协议(presentation layer protocol),能使使用者访问网络上别处的 ...

  6. Linux搭建NFS服务

    一.NFS服务简单介绍 NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源.在NFS的应用中, ...

  7. linux服务之NFS服务篇

    一.概念 NFS(Network File Server) 网络文件系统(映射).网络文件系统是FreeBSD支持的文件系统中的一种,也被称为NFS: NFS允许一个系统在网络上与他人共享目录和文件. ...

  8. NFS服务和DHCP服务讲解(week3_day2)--技术流ken

    NFS服务端概述 NFS,是Network File System的简写,即网络文件系统.网络文件系统是FreeBSD支持的文件系统中的一种,也被称为NFS: NFS允许一个系统在网络上与他人共享目录 ...

  9. 末学者笔记--NFS服务和DHCP服务讲解

    NFS服务端概述 一.概念: NFS,是Network File System的简写,即网络文件系统.网络文件系统是FreeBSD支持的文件系统中的一种,也被称为NFS:NFS允许一个系统在网络上与他 ...

随机推荐

  1. VB.NET机房收费 &amp; 抽象工厂模式

    学习设计模式的时候,提到了一个专门訪问数据库的模式-抽象工厂模式,记得当时举样例理解的时候并未设计到数据库,仅仅是大概了了解了一下,如今对于机房收费系统涉及到了数据库的管理,借此机会好好学习一下.用常 ...

  2. ios 使用Safari浏览器跳转打开、唤醒app

    常常使用Safari浏览器浏览网页点击url会唤醒该站点的手机版app 须要在app的project中设置 1.打开project中的myapp-Info.plist文件 2.打开文件里新增URL T ...

  3. 学习笔记—— 一些UPDATE语句

    UPDATE语句原来还有许多种写法,有的还很复杂,孤陋寡闻的我甚至闻所未闻.幸甚至哉,记而志之. 0.UPDATE 表名 SET 字段... FROM ...的方式 USE AdventureWork ...

  4. luogu1415 拆分数列

    题目大意 给出一列数字,需要你添加任意多个逗号将其拆成若干个严格递增的数.如果有多组解,则输出使得最后一个数最小的同时,字典序最大的解(即先要满足最后一个数最小:如果有多组解,则使得第一个数尽量大:如 ...

  5. CodeForces - 789D Weird journey

    D. Weird journey time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...

  6. B1607 [Usaco2008 Dec]Patting Heads 轻拍牛头 数学

    今天净做水题了,这个题还不到十五分钟就搞定了,思路特别简单,就是直接按照线性求因子个数的思路就行了. 题干: Description 今天是贝茜的生日,为了庆祝自己的生日,贝茜邀你来玩一个游戏. 贝茜 ...

  7. IJ-Error:常见错误

    ylbtech-IJ-Error:常见错误 1.返回顶部 1. This application has no explicit mapping for /error, so you are seei ...

  8. 第1课 Git、谁与争锋

    1-1  安装和使用Git http://git-scm.com/downloads Git的指令模式,才能够清楚地了解Git的工作细节.最后还会介绍Git Server的架设和管理,让读者能够熟练使 ...

  9. php的self和this

    <?phpclass ss{ public static $code; public function __construct( $code ) { self::$code=$code; //这 ...

  10. JVM内存模型和GC垃圾回收

    JVM 内存区域 1.程序计数器 这是一块较小的内存空间,它的作用可以看做是当前线程所执行的字节码的行号指示器,指的是上次代码被执行的地方,线程私有. 2.Java 虚拟机栈 它是 Java方法执行的 ...