9、varnish实现动静分离、负载均衡、后端服务器健康状态检测

varnish 4.0 版本

varnish实现动静分离
  1. # vim /etc/varnish/varnish.params 
  2. VARNISH_LISTEN_PORT=80 --> 修改为80端口
  1. # vim /etc/varnish/default.vcl 
  2. backend html {
  3.     .host = "10.1.249.125";
  4.     .port = "80";
  5. }
  6. backend app {
  7.     .host = "10.1.252.53";
  8.     .port = "80";
  9. }
  10. sub vcl_recv {
  11.     if (req.url ~ "(?i)\.php$") { --> (?i) 不区分字符大小写
  12.         set req.backend_hint = app;
  13.     } else {
  14.         set req.backend_hint = html;
  15.         }
  16. }
  1. # varnish_reload_vcl default.vcl --> 修改了vcl文件,需要重新编译
测试访问
9、varnish实现动静分离、负载均衡、后端服务器健康状态检测

 
9、varnish实现动静分离、负载均衡、后端服务器健康状态检测

 

此时可以看到,已经成功实现动静分离
但是我们也发现了存在一些问题:原来php Logo 的图标不见了
出现的问题的原因
查看网页源代码
9、varnish实现动静分离、负载均衡、后端服务器健康状态检测

 

修改vcl文件,使其网页内容能够完整显示
  1. sub vcl_recv {
  2.     if (req.url ~ "(?i)\.php") {       --> 将原来.php$ $ 去掉即可
  3.         set req.backend_hint = app;
  4.     } else {
  5.         set req.backend_hint = html;
  6.         }
  7. }
重新编译vcl文件
  1. # varnish_reload_vcl default.vcl
此处重启只是为了试验效果,在实际应用中,varnish一旦重启,缓存将会全部失效
  1. # systemctl restart varnish
9、varnish实现动静分离、负载均衡、后端服务器健康状态检测

 




varnish实现负载均衡
vcl文件的修改
  1. import directors; --> 放在vcl 4.0; 后面
  2. backend default {
  3.     .host = "10.1.249.125";
  4.     .port = "80";
  5. }
  6. backend server2 {
  7.     .host = "10.1.252.53";
  8.     .port = "80";
  9. }
  10. sub vcl_init {
  11.     new webapp = directors.round_robin();
  12.     webapp.add_backend(default);
  13.     webapp.add_backend(server2);
  14. }
  15. sub vcl_recv {
  16.     
  17.    set req.backend_hint = webapp.backend();   //顺序很重要,顺序很重要,顺序很重要,放在if 语句的前面
  18.     if (req.url ~ "^/test") {  -->定义在该路径下的内容不缓存,否则无法看出负载均衡的效果
  19.         return(pass);          -->第一次选中某台服务器后,后续可能会重缓存中直接返回结果
  20.     }
  21. }
//需要重新编译vcl文件,此处不再演示
9、varnish实现动静分离、负载均衡、后端服务器健康状态检测

 
9、varnish实现动静分离、负载均衡、后端服务器健康状态检测

 



后端服务器健康状态监测
  1. probe check {       --> 需要写在两个后端服务器之前,顺序很重要,顺序很重要,顺序很重要
  2.     .url = "/test/index.html";
  3.     .window = 5;
  4.     .threshold = 4;
  5.     .interval = 2s;
  6.     .timeout = 1s;
  7. }
  8. backend default {
  9.     .host = "10.1.249.125";
  10.     .port = "80";
  11.     .probe = check;
  12. }
  13. backend server2 {
  14.     .host = "10.1.252.53";
  15.     .port = "80";
  16.     .probe = check;
  17. }
//后面和负载均衡调用方式一样
//注意 probe check 要写在两个后端服务器之前
//顺序很重要
1、当后端两个服务器均正常时,可以正常进行调度
9、varnish实现动静分离、负载均衡、后端服务器健康状态检测

 
2、我们此时停掉server2的 http服务器,可以看到此时检测到server2 转态为sick
9、varnish实现动静分离、负载均衡、后端服务器健康状态检测

3、测试访问 
9、varnish实现动静分离、负载均衡、后端服务器健康状态检测

 
无论如何刷新,此时varnish不会再调度到server2上 

原创文章,作者:sixijie,如若转载,请注明出处:http://www.178linux.com/59043

(0)
sixijiesixijie
上一篇 2016-11-12 20:39
下一篇 2016-11-13 13:33

相关推荐

  • Linux虚拟网络接口-Bonding 配置

    一、bonding 的定义     bonding是通过将同一设备的多个物理网卡绑定到一个虚拟网卡上,再对外提供连接。对于外端来说,多个物理网卡共享虚拟网卡的IP和mac地址,也就表现为一个网卡设备。通过bonding技术可以实现高可用或者负载均衡。     bonding有7种工作模式:&nbsp…

    Linux干货 2017-07-02
  • 网络配置——命令家族

    Linux网络属性配置命令: ifcfg家族:ifconfig,route,netstat ifconfig命令:接口及地址查看和管理          ·ifconfig [INTERFACE]       &nbsp…

    Linux干货 2016-09-07
  • N26_第一周作业

    一、描述计算机的组成及其功能。 计算机系统:是由硬件(Hardware)系统和软件(Software)系统两大部分构成。 1、硬件系统: 1)控制器(Control):是整个计算机的中枢神经,其功能是对程序规定的控制信息进行解释,根据其要求进行控制,调度程序、数据、地址,协调计算机各部分工作及内存与外设的访问等。2)运算器(Datapath):运算器的功能是…

    2017-02-20
  • 第四周作业

    作业 1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@cloud ~]# cp -R /etc/skel /home/tuser1 && chmod -R…

    Linux干货 2016-12-25
  • Linux管理目录和文件命令

     管理目录命令: pwd:显示当前目录 Cd:   改变当前目录 ls:    查看目录下的内容 rmdir: 删除目录 管理文件命令: cat: 查看文件内容 cp: 复制文件内容 grep:在文件中查找某字符 touch:创建文件 rm&nbsp…

    2016-03-05
  • linux基础操作-week6

    1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; # cp /etc/rc.d/rc.sysinit /tmp #vim /tmp/rc.sysinit 末行模式: :%s@^[[:space:]]\{1,\}@#&@g 匹配分析:  &nbs…

    Linux干货 2016-11-28