搭建LAMP+NFS(附加mysql共享NFS目录练习总结)

练习一

环境布局

主机6 route A (10.1.32.14)作为DNS服务器

主机centos 7 class (10.1.32.3)作为Apache,PHP(模块方式)服务器1(有discuz程序)

主机centos 7 server (10.1.32.13)作为Apache,php(模块方式)服务器2(无discuz)

主机centos 6 class (10.1.32.4)作为NFS服务器

主机mini 7 (10.1.32.131)作为mysql服务器(同时作为访问Apache,使用discuz的客户端)

图像 015.png 


试验导图:


图像 017.png


试验前置操作:

关闭所有主机的防火墙和SElinux,以防试验时报各种错误!

 

实验步骤:

1搭建DNS服务器:

思路:

      yum安装bind包,编辑/etc/namd.conf 添加“discuz.com”域,并修改相关配置,然  

         后在/var/named/做相应文件的创建与配置。因为当用户输入www.discuz.com时要对应

         两台Apache(php)服务器上,以实现负载均衡效应,所以要配置两个A记录。

 

2搭建Apache,php服务器,mysql 服务器

思路:

yum快速部署Apache(两台服务器的apache用户的id都是48),php;mysql到3

台主机上,并开始阶段性测试

1)测试两台web服务器的php模块运行是否正常;

/var/www/html下创建index.php,添加phpinfo()函数,访问无问题!

2)测试两台web服务器连接mysql是否正常;

  mysql服务器上授权两台web服务器的权限,注意,IP(hostname),用户名,   密码不要写错!此时可以创建discuz的数据库,并一起授权,要不后面也要执行  

  这一步骤。  

 创建/var/www/html/conn.php 编辑mysql_connect()函数,测试通过!

    

  3)测试DNS服务器

     在客户端机(10.1.32.131)上编辑/etc/resolv.conf 添加nameserver=10.1.32.14

            将客户端机的DNS服务器指向这个主机,并在网卡配置文件里添加  

            DNS=10.1.32.14

            多次ping www.discuz.com 这个网站,发现它分别指向了10.1.32.3和10.1.32.13,     DNS服务器测试成功!

 

3 搭建NFS服务器

    思路:

yum 安装nfs-utils,注意(排错),如果系统没有安装rpcbind,或rpcbind服务未开启,

那么nfs 将 开启失败!创建/data/application/web,编辑/etc/exports ,添加相应路径的主

机权限。添加用 apache,id要保证与web服务器的apache用户一样!否则会导致

后期用户无权创建,修改文件!

 

4 挂载apache服务器(10.1.32.3)文件目录到NFS服务器

1)在10.1.32.3这个web服务器下创建一个目录/nfs-web/htdoc。用于存放discuz,

     web文件,上传的图片等,然后将此目录挂载到NFS服务器(10.1.32.4):

           mount -t nfs 10.1.32.4:/data/application/web /nfs-web/htdoc

      挂载成功!

 

  2)修改/etc/httpd/conf/httpd.conf文件的DocumentRoot 为挂载目录:

        /nfs-web/htdoc;然后验证php模块,mysql的各项功能是否正常。结果:一切正常!

     3)安装discuz,创建并登录一个用户,这里用windows端测试。

1】登录:

图像 002.png 

 

数据库数据确认:

 

  图像 008.png

 

数据正常!

 

2】上传头像:

图像 005.png 

图像 006.png 

 

用户头像的保存路径为NFS服务器的:

/data/application/web/discuz/uc_server/data/avatar/

 

图像 009.png 

3】修改个人信息:

图像 011.png 

 

至此为止,apache,PHP(10.1.32.3)–>NFS–>MySql 这一条线路就已经全部打通,此线路 测试完毕!接下来测试另一个apache,PHP(10.1.32.13)服务器。

 

5 挂载apache服务器(10.1.32.13)文件目录到NFS服务器

思路:

因为共享NFS的/data/application/web/目录,所以不用安装discuz,直接挂载,使用共享目录下的文件!然后登录同一用户,以此测试数据是否同步,多次刷新是否正常:

1】登录

图像 010.png 

 

2】上传的头像与用户信息


图像 013.png 

 

在任意一台服务器上另一台服务器均能得到正确数据,多次刷新也没有问题,到此为止,试验圆满结束!

 

练习二

试验环境:

两台mysql的服务器,一台NFS服务器。

思路与解答:

NFS服务器上开启nfs服务,创建文件/mysql/data,编辑配置文件/etc/exposts,赋予两台mysql服务器对此目录具有读写权限。添加用户mysql。先在其中一台服务器上安装mysql,创建/mydata,并将此目录挂载到NFS服务器的/mysql/data下,修改/etc/my.cnf,将datadir的目录位置改为已挂载的/mydata下。

保证mysql用户的id与NFS服务器的mysql用户的id一致。赋予mysql用户对/mydata的rwx权限。启动mysql服务,失败!但进入/mydata下,却发现,已经创建了部分文件,但查看日志,报错说在创建ibdata1这个文件时失败,原因是没有权限,但是反复查看,mysql用户应该是有权限的,因此怀疑是SElinux的作用,于是关闭SElinux,再启动,成功!

再在另一台服务器上安装mysql服务,执行和上述同样的操作,成功。然后分别测试两台mysql服务器在不同状态下的启动于关闭,没有问题!一台服务器创建的数据库和表,另一台也能同步到。但在表内的数据同步出现了问题!如:mysql服务器A插入了一条数据后,mysql服务器B不能立即同步,也就是看不到A插入的数据。当A再插入第二条数据后,B会同步出A插入的第二条数据,第一条数据在B里看不到,但在A里是完整的。反复测试仍不能解决…推测是表的同步机制或共享文件机制方面的问题。

 

 

原创文章,作者:菩提本无树,如若转载,请注明出处:http://www.178linux.com/54233

(0)
菩提本无树菩提本无树
上一篇 2016-10-25
下一篇 2016-10-25

相关推荐

  • 用户和组及批量创建

    用户和组       操作系统都有用户和组,windows,linux等等,用户和组用来做什么呢?       用户,是我们进入系统时的凭证,不是每一个人想进就进的。你想吧,如果操作系统没有用户就能登录进系统,那这就带来了许许多多的安全隐患了。而组则是为了方便管理用户的一个组容器。 &nb…

    系统运维 2016-08-04
  • 重构与模式:改善代码三部曲中的第三部

    一、改善代码的三部曲    《设计模式》-> 《重构》-> 《重构与模式》。也就是设计->重构->重构出新设计。    《设计模式》主要详细说明20几种模式,为我们带来了常见设计问题的经典解决方案,从而改变了整个面向对象开发的面貌。为设计而著。    《重构》改善既有代码的设…

    Linux干货 2015-04-07
  • 关于shell脚本编程基础第三篇

                          关于shell脚本编程基础第三篇   本章主要内容:循环的特殊用法;while;for;select 循环与菜单       &nbsp…

    系统运维 2016-08-21
  • 优秀程序员的十个习惯

    在这个世界上,有数百万的人热衷于软件开发,他们有很多名字,如:软件工程师(Software Engineer),程序员(Programmer),编码人(Coder),开发人员(Developer)。经过一段时间后,这些人也许能够成为一个优秀的编码人员,他们会非常熟悉如何用计算机语言来完成自己的工作。但是,如果你要成为一个优秀的程序员,你还可以需要有几件事你需…

    Linux干货 2015-04-01
  • 如何成为一名软件架构师

    Daniel Mohl是一名专业的软件工程师/架构师,他的兴趣包括理解各种复杂的编程语言、企业应用架构以及如何搭建业务与技术,他通晓F#、C#、CoffeeScript、JavaScript、Erlang、ASP.NET、MVC、WPF、WCF、Sliverlight、SQL Server等技术。有着多年的软件开发经验。 他经常会被一些有潜力和有前途的程序员…

    Linux干货 2016-03-22
  • 关于IO的同步,异步,阻塞,非阻塞

    上次写了一篇文章:Unix IO 模型学习。恰巧在这次周会的时候,@fp1203 (goldendoc成员之一) 正好在讲解poll和epoll的底层实现。中途正好讨论了网络IO的同步、异步、阻塞、非阻塞的概念,当时讲下来,大家的理解各不相同,各执己见。搜索了网络上的一些文章,观点也各不相同,甚至连wiki也将异步和非阻塞当成一个概念在解释。  &…

    Linux干货 2015-04-02