LVS负载均衡LAMP平台
需求说明搭建LAMP平台部署应用discuz,要求如下:
1、为了减轻单个服务器压力,部署两台WEB服务器,使用LVS-DR模式对服务器实现负载均衡。
2、将MySQL服务器和AP进行分离,两台AP访问同一台Mysql服务器,实现数据库数据一致性。
3、AP的网页文件都存储在NFS共享存储上,实现网页文件一致性。
架构缺陷:
LVS单点,Mysql单点,NFS单点,交换机单点,这些设备一旦有一个出现问题,就会导致网站访问出错;当然也有很多解决方法,如LVS可以lvs+keeplive避免单点,Mysql可以做主从同步,NFS可以做分布式文件系统,交换机可以做冗余链路。这些会在后期博文,给出文章。
实验拓扑
http://s3.运维网.com/wyfs02/M02/6D/9C/wKiom1VnQU2xVIV_AAJUTtw5yWc399.jpg
部署NFS
安装NFS,系统默认自带
# 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页面文件的地方,而且需要保证用户有写权限。
# mkdir /LAP
# vim /etc/exports
/LAP 172.16.4.101(rw) 172.16.4.102(rw) 启动nfs,验证共享
# service nfs start
# showmount -e 172.16.4.136
Export list for 172.16.4.136:
/LAP 172.16.4.102,172.16.4.101 客户端挂载
# mount -t nfs 172.16.4.136:/LAP /var/www/html/
# mount -t nfs 172.16.4.136:/LAP /var/www/html/ 查看是否挂载
# df -h
172.16.4.136:/LAP 20G 285M 19G 2% /var/www/html
# df -h
172.16.4.136:/LAP 20G 285M 19G 2% /var/www/html部署Mysql
安装Mysql
# yum -y install mysql-server 启动Mysql
# service mysqld start
# 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不许要启动
# yum -y install php php-mysql mysqlmysql-server
# yum -y install php php-mysql mysql mysql-server 设置完成启动httpd服务即可,其他都无需配置LAMP平台就搭建好了
# service httpd start
# service httpd start 验证httpd连接php
在NFS服务设置测试页面
# vim /LAP/index.php
http://s3.运维网.com/wyfs02/M00/6D/98/wKioL1VnQuDixLhwAAK9ny9euXs489.jpg
测试连接Mysql
Mysql设置root允许远程连接
mysql> GRANT ALL PRIVILEGES ON *.* TO'root'@'172.16.%.%';
mysql> flush privileges; nfs创建测试页面
# vim /LAP/index.php
分别访问两台WEB服务器都可以正常连接Mysql
http://s3.运维网.com/wyfs02/M00/6D/9C/wKiom1VnQU7za3RxAACUBzV6XNU541.jpg
http://s3.运维网.com/wyfs02/M01/6D/98/wKioL1VnQuGA_W-BAACWXKSFHqM653.jpg
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共享目录
# unzip Discuz_7.2_FULL_SC_UTF8.zip -dDiscuz
# mv Discuz/upload/* /LAP/ 随便输入LAP中的一个ip地址,url后面+install就可以安装了
http://s3.运维网.com/wyfs02/M01/6D/9C/wKiom1VnQU_Qp0UVAAF6PtoOK7o371.jpg
解决问题:
# vim /etc/php.ini
short_open_tag = ON
# scp /etc/php.iniroot@172.16.4.102:/etc/php.ini 设置完成重启web服务器
又有了一个写权限问题,如下图所示
http://s3.运维网.com/wyfs02/M02/6D/98/wKioL1VnQuLhL5GVAAJY6ntP-CY090.jpg
由于NFS的权限是更具用户id进行验证的,而MN的apache和LAP1,LAP2的apache用户id一致,所以直接对apache用户进行授权写操作。
# 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号就可以继续了
http://s3.运维网.com/wyfs02/M02/6D/9C/wKiom1VnQVCgOXTbAAIzu5YOawE346.jpg
设置数据库相关信息,需要正确填写数据库的地址,用户名和密码才可以安装。
http://s3.运维网.com/wyfs02/M00/6D/98/wKioL1VnQuTCyElqAAId1waB7XU868.jpg
安装完成出现的界面
http://s3.运维网.com/wyfs02/M00/6D/9C/wKiom1VnQVOxEhdYAAJKnYQzPKM247.jpg
刚才安装是在172.16.4.101安装完成的,在172.16.4.102没有进行安装,但是由于NFS共享的原因,在4.101安装完成的时候,NFS的文件也就进行修改,所以访问4.102的时候,就是访问安装好的文件。
http://s3.运维网.com/wyfs02/M01/6D/98/wKioL1VnQueynLPmAAHDeVH2Ekg915.jpg
部署LVS-DR
调度器设置
安装ipvsadm
# yum -y install ipvsadm 设置vip地址
# ifconfig eth0:0 172.16.4.1 netmask255.255.255.255 up
# 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 配置负载均衡策略
# ipvsadm -A -t 172.16.4.1:80 -s rr
# ipvsadm -a -t 172.16.4.1:80 -r172.16.4.101 -g -w 1
# ipvsadm -a -t 172.16.4.1:80 -r172.16.4.102 -g -w 1
# 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 0LAP1设置
# echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
# echo "2">/proc/sys/net/ipv4/conf/lo/arp_announce
# echo "1">/proc/sys/net/ipv4/conf/all/arp_ignore
# echo "2">/proc/sys/net/ipv4/conf/all/arp_announce
# ifconfig lo:0 172.16.4.1 broadcast172.16.4.1 netmask 255.255.255.255 up
# 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
# route add -host 172.16.4.1 dev lo:0LAP2设置
# echo "1">/proc/sys/net/ipv4/conf/lo/arp_ignore
# echo "2">/proc/sys/net/ipv4/conf/lo/arp_announce
# echo "1">/proc/sys/net/ipv4/conf/all/arp_ignore
# echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
# ifconfig lo:0 172.16.4.1 broadcast172.16.4.1 netmask 255.255.255.255 up
# 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
# route add -host 172.16.4.1 dev lo:0 设置完成就可以使用vip地址访问bbs了。
页:
[1]