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

相关推荐

  • 第二十二周作业

    1、请描述本地文件系统和分布式文件系统的特点; 本地文件系统: 本地文件系统主要是指Ext2,Ext3,Btrfs,XFS这类(很难概括,只好举例子),它们通常提供以下功能: 1.扩展性:随着系统容量的增加保持性能,不随容量变化而导致性能震荡。比如一个目录下的海量文件,在EXT2/3中由于目录设计问题会导致较大的性能问题。再比如EXT2/3中的Metadat…

    2017-09-23
  • 自制Linux系统实验

    1、添加一块新硬盘、并使系统识别 [root@centos6 ~]# echo "- – -" > /sys/class/scsi_host/host0/scan  [root@centos6 ~]# echo "…

    Linux干货 2016-09-19
  • mysql/mariadb基于ssl的主从复制

     当mysql/mariadb跨越互联网进行复制时别人可以窃取到mysql/mariadb的复制信息, 这些信息是明文的, 因此存在不安全性, 这里通过ssl对复制的信息进行加密      1. 创建证书中心 在主服务器上创建证书中心 cd /etc/pki/CA 生成私钥 (umask&…

    Linux干货 2016-12-05
  • 马哥教育网络班N22期+第6周课程练习

    一、总结vim编辑器的使用方法 vim文本编辑器 全屏编辑器,模式化编辑器 vim的教程文件命令:vimtutor vim /path/to/somefile vim模式: 编辑模式(命令模式),默认模式 输入模式 末行模式 内置的命令行接口; 模式转换: 编辑模式—>输入模式: i:insert, 在光标所在处前方输入,转为输入模式 a:append…

    Linux干货 2016-10-09
  • 马哥教育网络21期+第6周博客练习

    请详细总结vim编辑器的使用并完成以下练习题 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; :%s@\(^[[:space:]]\+\)@#&@g # Let rhgb know that we&#0…

    Linux干货 2016-08-15
  • 二.Linux博客-2016年7月21日screen、echo

    格式说明: 操作 概念 命令 说明及举例 二.screen、echo internet 因特网ethernet 以太网ctrl+alt+F1 图形界面ctrl+alt+F2-F6 字符界面 命令:who am i/who/who me i/tty/df/ifconfig/w/ halt 关机 reboot&n…

    Linux干货 2016-08-24