练习一
环境布局:
主机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的客户端)
试验导图:
试验前置操作:
关闭所有主机的防火墙和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】登录:
数据库数据确认:
数据正常!
【2】上传头像:
用户头像的保存路径为NFS服务器的:
/data/application/web/discuz/uc_server/data/avatar/
【3】修改个人信息:
至此为止,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】登录
【2】上传的头像与用户信息
在任意一台服务器上另一台服务器均能得到正确数据,多次刷新也没有问题,到此为止,试验圆满结束!
练习二
试验环境:
两台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