NFS 实现wordpress同步

0x00 NFS概述

网络文件系统(英语:Network File System,缩写为NFS)是一种分布式文件系统协议,最初由Sun Microsystems公司开发,并于1984[1]年发布。其功能旨在允许客户端主机可以像访问本地存储一样通过网络访问服务器端文件。 NFS和其他许多协议一样,是基于开放网络运算远程过程调用(ONC RPC) 协议之上的。
NFS是一个开放、标准的RFC协议,任何人或组织都可以依据标准实现它。

0x01 NFS实现原理

当一台计算机(客户端)需要访问存储在其他机器上的数据(NFS 服务器):

  1. 服务端实现 NFS 守护进程, 默认运行 nfsd, 用来使得数据可以被客户端访问.
  2. 服务端系统管理员可以决定哪些资源可以被访问, 导出目录的名字和参数, 通常使用 /etc/exports 配置文件 和exportfs命令。
  3. 服务端 安全-管理员 保证它可以组织和认证合法的客户端.
  4. 服务端网络配置保证可以跟客户端透过 防火墙 进行协商.
  5. 客户端请求导出的数据, 通常调用一个 mount 命令.
  6. 如果一切顺利, 客户端的用户就可以通过已经挂载的 文件系统 查看和访问服务端的文件了.

0x02 NFS 相关配置及命令

  • NFS 软件包 : nfs-utils-1.3.0-0.33.el7.x86_64
  • /etc/exports或/etc/exports.d/*

    /PATH/TO/SOME_DIR clients1(export_options, …) clients2(export_options, …)

    注意/etc/exports.d/ 下的文件必须以 .exports 结尾

    clients:
            single host:ipv4, ipv6, FQDN;
            network:address/netmask, 同时长短格式的掩码;
            wildcards:主机名通配,例如:*.magedu.com;
            netgroups:NIS域内的主机组;@group_name;
            anonymous:使用*通配所有主机;
    
    export_options:     
    
            General Options:
                        ro:只读
                        rw:读写;
                        sync:同步;
                        async:异步;
            User ID Mapping:
                     root_squash:压缩root用户,一般指将其映射为nfsnobody;
                     no_root_squash:不压缩root用户;
                     all_squash:压缩所有用户;
                     anonuid and anongid:将压缩的用户映射为此处指定的用户;
  • 两个命令:exportfs和showmount

    • exportfs- maintain table of exported NFS file systems
      exportfs [-av] -u [client:/path ..]
      eg: exportfs -av -u 172.18.9.9:/data

      -a     Export or unexport all directories.
      
      -r     Reexport  all  directories
      
      -u     Unexport one or more directories.
    • showmount- show mount information for an NFS server

      -a or --all
      
      -d or --directories
                List only the directories mounted by some client.
      
      -e or --exports
                Show the NFS server’s export list.

0x03 NFS实践作业(一)

实验要求:

(1) nfs server导出/data/目录;
(2) nfs client挂载/data/至本地的/mydata目录;本地的mysqld或mariadb服务的数据目录设置为/mydata, 要求服务能正常启动,且可正常 存储数据;

实验环境:

  • NFS_server : centos7.3 ,IP ( 172.18.9.119 )
  • NFS_client : centos6.8 , IP ( 172.18.9.9 )

实验步骤:

  • NFS_server:

    1. ! rpm -q nfs-utils >/dev/null  && yum install -y nfs-utils  #安装nfs 
    
    2. systemctl  start nfs.service
    
    3. mkdir /data  #创建共享目录
    
    4. vim /etc/exports.d/mysql_data.exports
        /data/   172.18.9.9(rw,anonuid=27,anongid=27,async)
    
    5. exportfs  -ar
    
    6. setfacl -m o:rwx  /data
  • NFS_client

    1. yum install -y  nfs-utils
    
    2. yum install -y mysql-server
    
    3. mkdir /mydata
    
    4. mount  -t nfs  172.18.9.119:/data   /mydata
    
    5. vim  /etc/my.cnf
            datadir=/mydata
    
    6. service  mysqld  start

    注意: 上述步骤有先后顺序,请严格执行

0x04 NFS实践作业(二)

实验要求:

(1) nfs server导出/data/application/web,在目录中提供wordpress;
(2) nfs client挂载nfs server导出的文件系统至/var/www/html;
(3) 客户端(lamp)部署wordpress,并让其正常访问;要确保能正常发文章,上传图片;
(4) 客户端2(lamp),挂载nfs server导出的文件系统至/var/www/html;验正其wordpress是否可被访问; 要确保能正常发文章,上传图片;

实验环境:

NFS_server : centos7.3 , IP : 172.18.9.119
NFS_client_1: centos6.8 , IP : 172.18.9.9
NFS_client_2: centos6.8, IP : 172.18.9.10

实验步骤:

  • NFS_server:

    1. yum install -y nfs-utils  #安装nfs 
    
    2. systemctl  start nfs.service
    
    3. mkdir -p /data/application/web  #创建共享目录
    
    4. vim /etc/exports.d/data_app_web.exports
            /data/   172.18.9.9(rw,async)     172.18.9.10(rw,async)
    
    5. exportfs  -ar
    
    6. setfacl -R -m o:rwx  /data/application/web  #注意:此权限一定要设定,不然client会无法挂载访问
  • NFS_client_1: 部署 wordpress

    1. yum install -y httpd mysql-server php php-mysql
    
    2. wget https://wordpress.org/latest.zip  && unzip latest.zip  && mv  wordpress  /var/www/html/    #下载wordpress 并解压至 /var/www/html
    
    
    ###  设置wordpress 数据库  ###
    
    3. mysql
        mysql> create database wpdb;
        # 出现 Query OK, 0 rows affected (0.00 sec) 即为成功
        mysql> grant all privileges on wpdb.* to wpuser@'%' identified by "mima";
        mysql> exit;
    
    4. service mysqld start   # 启动mysql 服务  
    
    5. mount 172.18.9.119:/data/application/web  /var/www/html/   #挂载nfs 共享目录至 /var/www/html
    
    6. service httpd  #启动httpd 服务
    
    7. # 安装wordpress

NFS 实现wordpress同步NFS 实现wordpress同步

….. 剩下的自己看情况设置……

到此wordpress 以经建好,可以发布文章了。(在浏览器中输入: http://172.18.9.9/wordpress/

  • NFS_client_2:

    1. yum install -y httpd mysql-server php php-mysql
    
    2. mount 172.18.9.119:/data/application/web  /var/www/html/   #挂载nfs 共享目录至 /var/www/html
    
    3. service httpd start
    
    4. service mysqld start

    在浏览器中输入: http://172.18.9.10/wordpress/
    登录,即可发表文章,并能查看client_1 发表的文章。

0x05 常见问题

  1. mount.nfs: access denied by server while mounting 172.18.9.119:/data/application/web
    这是因为nfs_server端的共享目录没有执行权限

    解决方案:
    在nfs_server执行: setfacl -m o:rwx /data/application/web

  2. mount nfs后, 如果遇到服务器修改 /etc/exports 等原因时,经常会遇到

    Text代码

    umount2: Stale NFS file handle  
    umount: htdocs: Stale NFS file handle

    或者
    Text代码

    /var/www/html was not found in /proc/mounts

    等问题

    解决方案:

    找到使用目录的进程, kill掉
    sudo umount -i -f /directory
    sudo umount -i -d -r -n -v -f  /directory

原创文章,作者:Yanglibin,如若转载,请注明出处:http://www.178linux.com/74462

(0)
YanglibinYanglibin
上一篇 2017-04-30
下一篇 2017-04-30

相关推荐

  • 初识 vi/vim文本编辑器

    我们操作文件,终究离不开编辑文件,对文件内容的编辑,Linux系统下,我们通常使用VI/VIM来编辑文件。VI是每个Linux都会自带的文本编辑器,VIM是VI的增强版,现在的最新版都已自带,但是可能有些发行版本没有自带,可以使用sudo apt-get install vim命令安装vim。 可以使用vi或者vim命令直接进入新的文本文件,或者vim 文件…

    Linux干货 2017-07-29
  • 引导加载程序grub的使用详解

    引导加载程序grub的使用详解 为运行于虚拟机上的CentOS 6添加一个新硬件,提供两个主分区 为硬盘建两个主分区;并为其安装grub 为硬盘的第一个主分区提供内核和ramdisk文件;为第二个分区提供rootfs 为rootfs提供bash、ls、cat程序以及所依赖的库文件 为grub提供配置文件 将新的硬盘设置为第一启动项并能够正常启动目标主机 1.…

    Linux干货 2017-09-04
  • N25-第11周博客作业

    1、详细描述一次加密通讯的过程,结合图示最佳。 第一步:他们需要实现协商好对称加密算法,单向加密算法,公钥加密算法,交换公钥等。 第二步:B用户想要将数据传给A,首先需要使用单向加密算法取出数据的特征码,并用自己的私钥对这段特征码进行加密(数字签名),B用户生成临时对称密钥,并用对称密钥加密整段数据,B用户使用 A用户的公钥加密一次性对称密钥,附加在整段数据…

    Linux干货 2017-05-21
  • N22-妙手-第七周课程练习

    1、创建一个10G分区,并格式为ext4文件系统;    (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl; [root@localhost ~]# mke2fs -t ext4 -m 2 -L MY…

    Linux干货 2016-10-09
  • Linux文件类型及把剩下的颜色标识

    Linux文件类型及bash下的颜色标识 Linux一切皆文件 查看文件类型的命令: 例如:列出ls的文件类型                file  /bin/ls 例如:粗略的列出文件类型           &n…

    Linux干货 2016-10-16
  • 马哥教育网络班22期第三周课程练习1

    1、who | awk {'print $1'} | sort | uniq  2、last | head -n1 3、awk -F":" {'print $7'} /etc/passwd |  awk '{for(i=1;i<=NF;i++)a[$i]++}EN…

    Linux干货 2016-08-29