(1) 动静分离部署wordpress,动静都要能实现负载均衡,要注意会话的问题;

(2) 在haproxy和后端主机之间添加varnish进行缓存;

(3) 设计拓扑;

(4) haproxy的设定要求:

(a) stats page,要求仅能通过本地访问使用管理接口;

(b) 动静分离;

(c) 分别考虑不同的服务器组的调度算法;

(5) haproxy高可用;

实验规划:

利用keepalived主备高可用两个haproxy服务器

对varnish缓存服务器做高可用

动态web集群

静态web集群

haproxy1: 172.16.1.4

haproxy2: 172.16.1.2

varnish1: 172.16.1.5

varnish2: 172.16.1.6

dynamic server1:172.16.1.3

dynamic server2:172.16.1.7

static server1: 172.16.1.10

static server2: 172.16.1.8

拓扑图

00.PNG

一、两台haproxy配置文件配置

haproxy1.PNG

haproxy2.PNG

启动服务

~]# systemctl start haproxy

~]# systemctl status haproxy #查看状态

~]# ss -tnlp #查看80和9999端口是否启用

~]# systemctl enable haproxy #设置开机启动

二、keepalived的配置

haproxy1的keepalived配置

11111.PNG

haproxy2的keepalived配置

22222.PNG

三、两台varnish主机的配置

更改varnish的监听端口为80

[root@varnish1 ~]# vim /etc/varnish/varnish.params

VARNISH_LISTEN_PORT=80

varnish配置文件内容

[root@varnish1 ~]# vim /etc/varnish/default.vcl

aaa.PNG

bbb.PNG

ccc.PNG

编译使配置生效

[root@varnish1 ~]# varnishadm -S /etc/varnish/secret -T 127.0.0.1:6082

200


Varnish Cache CLI 1.0


Linux,3.10.0-327.el7.x86_64,x86_64,-smalloc,-smalloc,-hcritbit

varnish-4.0.5 revision 07eff4c29

Type 'help' for command list.

Type 'quit' to close CLI session.

vcl.list

200

available 0 boot

active 0 myconf3

varnish> vcl.load conf1 default.vcl

200

VCL compiled.

vcl.use conf1

200

VCL 'conf1' now active

vcl.list

200

available 0 boot

available 0 myconf3

active 0 conf1

四、后端动静服务器wordpress主机配置

后端amp配置不做赘述

在动态主机的/var/www/html/下创建health.php用于动态健康状态检查

DynamicServer is Health.

在静态主机的/var/www/html/下创建health.html用于静态健康状态检查

StaticServer is Health.

五、客户端查看

客户端登陆haproxy的stats page

登陆.PNG

关闭一台varnish服务器后,可以在stats page看到一台正常运行,一台关闭了

登陆2.PNG

登陆wordpress可以看到之前正常上传图片的博客

捕获.PNG

六、总结

1、架构优点:

(1)HAProxy为Varnish缓存服务器提供了高可用的负载均衡,其使用的算法,也为Varnish提升了缓存命中率;

(2)HAProxy提供Web图形化管理界面,使得管理更加便捷高效;

(3)Varnish的高效缓存机制极大的提升了Web应用的性能,降低了Web服务器的压力;

(4)Varnish给后端Web服务器提供了高可用负载均衡,并使用了动态分离技术,保障了后端主机的冗余,显著提升了其性能;

(5)使用Keepalive对HAproxy做高可用解决了单点故障问题。

2、不足之处:

(1)该架构没有解决存储的问题。

解决方案:可以使用NFS+Rsync+inodify实现数据实时同步,再用keepalive做高可用。

(2)MysqlServer,没有分离

解决方案:独立数据库服务器,对其设置数据库主从复制,读写分离;