需求说明
搭建LAMP平台部署应用discuz,要求如下:
1、为了减轻单个服务器压力,部署两台WEB服务器,使用LVS-DR模式对服务器实现负载均衡。
2、将MySQL服务器和AP进行分离,两台AP访问同一台Mysql服务器,实现数据库数据一致性。
3、AP的网页文件都存储在NFS共享存储上,实现网页文件一致性。
架构缺陷:
LVS单点,Mysql单点,NFS单点,交换机单点,这些设备一旦有一个出现问题,就会导致网站访问出错;当然也有很多解决方法,如LVS可以lvs+keeplive避免单点,Mysql可以做主从同步,NFS可以做分布式文件系统,交换机可以做冗余链路。这些会在后期博文,给出文章。
实验拓扑
部署NFS
安装NFS,系统默认自带
[[email protected] ~]# rpm -qa | grep nfs nfs-utils-1.2.3-54.el6.x86_64 nfs-utils-lib-1.1.5-9.el6.x86_64 nfs4-acl-tools-0.3.3-6.el6.x86_64
设置NFS共享,这个共享的目录以后就是存放web页面文件的地方,而且需要保证用户有写权限。
[[email protected] ~]# mkdir /LAP [[email protected] ~]# vim /etc/exports /LAP 172.16.4.101(rw) 172.16.4.102(rw)
启动nfs,验证共享
[[email protected] ~]# service nfs start [[email protected] ~]# showmount -e 172.16.4.136 Export list for 172.16.4.136: /LAP 172.16.4.102,172.16.4.101
客户端挂载
[[email protected] ~]# mount -t nfs 172.16.4.136:/LAP /var/www/html/ [[email protected] ~]# mount -t nfs 172.16.4.136:/LAP /var/www/html/
查看是否挂载
[[email protected] ~]# df -h 172.16.4.136:/LAP 20G 285M 19G 2% /var/www/html [[email protected] ~]# df -h 172.16.4.136:/LAP 20G 285M 19G 2% /var/www/html
部署Mysql
安装Mysql
[[email protected] ~]# yum -y install mysql-server
启动Mysql
[[email protected] ~]# service mysqld start [[email protected] ~]# netstat -lnt | grep :3306 tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN
部署LAP
Centos6.6已经内置了httpd所以无需安装,安装Mysql是php依赖Mysql,但是Mysql不许要启动
[[email protected] ~]# yum -y install php php-mysql mysql mysql-server [[email protected] ~]# yum -y install php php-mysql mysql mysql-server
设置完成启动httpd服务即可,其他都无需配置LAMP平台就搭建好了
[[email protected] ~]# service httpd start [[email protected] ~]# service httpd start
验证httpd连接php
在NFS服务设置测试页面
[[email protected] ~]# vim /LAP/index.php <?php phpinfo(); ?>
测试连接Mysql
Mysql设置root允许远程连接
mysql> GRANT ALL PRIVILEGES ON *.* TO‘root‘@‘172.16.%.%‘; mysql> flush privileges;
nfs创建测试页面
[[email protected] ~]# vim /LAP/index.php <?php $conn=mysql_connect(‘172.16.4.136‘,‘root‘,‘‘); if ($conn) echo "连接数据库成功"; else echo "连接数据库失败" ?>
分别访问两台WEB服务器都可以正常连接Mysql
LAMP平台准备ok就可以部署discuz了
部署Discuz
创建Discuz数据库和连接用户
mysql> create database bbsdb; mysql> GRANT all ON bbsdb.* TO‘runbbs‘@‘172.16.4.101‘ IDENTIFIED BY ‘adm123‘; mysql> GRANT all ON bbsdb.* TO‘runbbs‘@‘172.16.4.102‘ IDENTIFIED BY ‘adm123‘; mysql> flush privileges;
将Discuz安装的网页文件放到NFS共享目录
[[email protected] ~]# unzip Discuz_7.2_FULL_SC_UTF8.zip -dDiscuz [[email protected] ~]# mv Discuz/upload/* /LAP/
随便输入LAP中的一个ip地址,url后面+install就可以安装了
解决问题:
[[email protected] ~]# vim /etc/php.ini short_open_tag = ON [[email protected] ~]# scp /etc/[email protected]:/etc/php.ini
设置完成重启web服务器
又有了一个写权限问题,如下图所示
由于NFS的权限是更具用户id进行验证的,而MN的apache和LAP1,LAP2的apache用户id一致,所以直接对apache用户进行授权写操作。
[[email protected] LAP]# setfacl -m u:apache:rwx./config.inc.php ./attachments/ ./forumd ata/ ./forumdata/cache/ ./forumdata/templates/ ./forumdata/threadcaches/ ./foru mdata/logs/ ./uc_client/data/cache/
如果检测都没有x号就可以继续了
设置数据库相关信息,需要正确填写数据库的地址,用户名和密码才可以安装。
安装完成出现的界面
刚才安装是在172.16.4.101安装完成的,在172.16.4.102没有进行安装,但是由于NFS共享的原因,在4.101安装完成的时候,NFS的文件也就进行修改,所以访问4.102的时候,就是访问安装好的文件。
部署LVS-DR
调度器设置
安装ipvsadm
[[email protected] ~]# yum -y install ipvsadm
设置vip地址
[[email protected] ~]# ifconfig eth0:0 172.16.4.1 netmask255.255.255.255 up [[email protected] ~]# ifconfig | grep 172.16.4.1 inet addr:172.16.4.100 Bcast:172.16.255.255 Mask:255.255.0.0 inet addr:172.16.4.1 Bcast:172.16.4.1 Mask:255.255.255.255
配置负载均衡策略
[[email protected] ~]# ipvsadm -A -t 172.16.4.1:80 -s rr [[email protected] ~]# ipvsadm -a -t 172.16.4.1:80 -r172.16.4.101 -g -w 1 [[email protected] ~]# ipvsadm -a -t 172.16.4.1:80 -r172.16.4.102 -g -w 1 [[email protected] ~]# ipvsadm -L -n IP Virtual Server version 1.2.1 (size=4096) Prot LocalAddress:Port Scheduler Flags -> RemoteAddress:Port Forward Weight ActiveConn InActConn TCP 172.16.4.1:80 rr ->172.16.4.101:80 Route 1 0 0 ->172.16.4.102:80 Route 1 0 0
LAP1设置
[[email protected] ~]# echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore [[email protected] ~]# echo "2">/proc/sys/net/ipv4/conf/lo/arp_announce [[email protected] ~]# echo "1">/proc/sys/net/ipv4/conf/all/arp_ignore [[email protected] ~]# echo "2">/proc/sys/net/ipv4/conf/all/arp_announce [[email protected] ~]# ifconfig lo:0 172.16.4.1 broadcast172.16.4.1 netmask 255.255.255.255 up [[email protected] ~]# ifconfig | grep 172.16.4.1 inet addr:172.16.4.101 Bcast:172.16.255.255 Mask:255.255.0.0 inet addr:172.16.4.1 Mask:255.255.255.255 [[email protected] ~]# route add -host 172.16.4.1 dev lo:0
LAP2设置
[[email protected] ~]# echo "1">/proc/sys/net/ipv4/conf/lo/arp_ignore [[email protected] ~]# echo "2">/proc/sys/net/ipv4/conf/lo/arp_announce [[email protected] ~]# echo "1">/proc/sys/net/ipv4/conf/all/arp_ignore [[email protected] ~]# echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce [[email protected] ~]# ifconfig lo:0 172.16.4.1 broadcast172.16.4.1 netmask 255.255.255.255 up [[email protected] ~]# ifconfig | grep 172.16.4.1 inet addr:172.16.4.102 Bcast:172.16.255.255 Mask:255.255.0.0 inet addr:172.16.4.1 Mask:255.255.255.255 [[email protected] ~]# route add -host 172.16.4.1 dev lo:0
设置完成就可以使用vip地址访问bbs了。