1. 安装依赖包:
  2. tar -zxvf docutils-0.13.1.tar.gz
  3. python setup.py install
  4.  
  5. unzip pcre2-10.23.zip
  6. ./configure --prefix=/usr/local/pcre2
  7. make
  8. make install
  9.  
  10. export PKG_CONFIG_PATH="/usr/local/pcre2/lib/pkgconfig"
  11. export -p //查看输出
  12.  
  13. yum install pcre-devel -y
  14. yum intall ncurses-devel -y
  15. rpm -ivh libedit-devel-2.11-4.20080712cvs.1.el6.x86_64.rpm
  16.  
  17. 创建用户、组及缓存和日志目录:
  18. useradd varnish
  19. mkdir /data/varnish/cache -p
  20. mkdir /data/varnish/log -p
  21. chown varnish.varnish -R /data/varnish/cache/
  22. chown varnish.varnish -R /data/varnish/log/
  23.  
  24. 安装varnish
  25. tar -zxvf varnish-4.1.5.tar.gz
  26. ./configure --prefix=/usr/local/varnish --enable-dependency-tracking --enable-debugging-symbols --enable-developer-warnings
  27. make
  28. make install
  29.  
  30. 拷贝配置文件:
  31. [root@localhost varnish-4.1.5]# cp etc/example.vcl /usr/local/varnish/
  32.  
  33. 启动varnish //注意与80端口的冲突问题
  34. [root@localhost varnish]# sbin/varnishd -f /usr/local/varnish/example.vcl -s malloc,1G -T 127.0.0.1:2000 -a 0.0.0.0:80
  35.  
  36. -a address[:port][ -a address[:port][...] //监听指定的地址和端口的客户端请求。
  37. -b host[:port] //使用指定的主机作为后端服务器。 如果没有指定端口,默认为8080。类似 -f 的VCL文件中backend命令可以指定反向入口地址与端口,但只能指定一个。是一个快捷启动方式。不能与 -f 同时存在
  38. -d //启用调试模式:父进程运行在与标准输入/输出一个CLI连接的前景,和子进程必须明确使用CLI命令启动。 终止父进程也将终止子。
  39. -f config //使用指定的VCL配置文件代替内置的默认值。不能与 -b 同时存在,但必需指定一个,否则服务无法启动
  40. -h type[,options] //指定的哈希算法。 hash列表类型,以及长度.默认长度是16383.。
  41. -l shl[,free[,fill]] //指定shmlog文件的大小。 shl 是共享内存日志记录(默认80M),free 是空闲空间,fill 是已经使用空间。内存大小可以设置‘K’,'M' 等。
  42. -n name //临时文件实例名.如果以"/"开头,就必须是一个可用的路径. 其实就是工作目录
  43. -P file //写进程的PID到指定的文件。
  44. -p param=value //定参数指定为指定的值。用来优化性能
  45. -s [name=]type[,options]
  46. 缓存设置,有三种方式:
  47. malloc[,size] (内存+swap交换模式)
  48. file[,path[,size[,granularity]]] (文件形式)
  49. persistent,path,size (文件形式)
  50.  
  51. Malloc (malloc) 通过 malloc 获取内存,简单,速度快
  52. Mmap file (file) 创建文件缓存
  53. 这个是varnish缓存的两种方式,可以在启动的时候通过参数指定。
  54.  
  55. granularity用于设定缓存空间分配单位,默认单位是字节,所有其它的大小都会被圆整。
  56. size 是指定空间大小,可以是G,M,K等。
  57. path 是文件目录
  58.  
  59. -w int[,int[,int]] //指定varnish的 工作线程数,常用的方式有:
  60. -w minmax
  61. -w minmaxtimeout
  62. -w55120030
  63. 注:不能将最小设定过大,否则运行的速度异常缓慢。
  64.  
  65. -T address[:port] //管理器端口。CLI 入口地址与端口,使用 talnet 命令可以进入 CLI 界面管理服务器,也可以使用varnishadm
  66. -t ttl //指默认TTL值
  67. -V/v //显示版本号并退出/显示版本信息
  68.  
  69. 停止varnish
  70. pkill varnishd (直接杀死进程,只能使用上面的命令启动varnish
  71. 或者
  72. varnishadm stop (需要进入安装目录的bin目录下,只是关闭了子进程,可以使用varnishadm start 再次开启服务或者使用上面的启动命令)

一、Varnish简介
Varnish是一款高性能、开源的反向代理服务器和缓存服务器,其开发者Poul-Henning Kamp是FreeBSD核心的开发人员之一。
Varnish主要运行两个进程:Management进程和Child进程(也叫Cache进程)。
Management
进程主要实现应用新的配置、编译VCL、监控varnish、初始化varnish以及提供一个命令行接口等。Management进程会每隔几秒钟探测
一下Child进程以判断其是否正常运行,如果在指定的时长内未得到Child进程的回应,Management将会重启此Child进程。

1)、
varnish从客户端接收请求后,由vcl_recv状态引擎处理,不能识别的请求将会通过参数pipe交给vcl_pipe状态引擎,需要查找缓存的
请求通过lookup参数将会交给vcl_hash状态引擎,无需缓存的数据通过参数pass将会交给 vcl_pass状态引擎;
2)、

vcl_hash状态引擎在接收到请求后会从缓存中查找数据,查询结果有两种,一种是hit缓存命中,另一种是miss缓存未命中;
3)、

vcl_hit状态引擎将命中的缓存数据通过参数deliver交给vcl_deliver状态引擎,vcl_deliver状态引擎将数据处理后,最终返回给客户端;
4)、

vcl_miss状态引擎将未命中的结果参数fetch交给vcl_fetch状态引擎,vcl_fetch状态引擎将会从数据库中查找数据;
5)、

vcl_fetch状态引擎将从数据库中查询到的结果,返回给vcl_deliver状态引擎;
6)、

vcl_deliver状态引擎将结果返回给master进程,最终返回给客户端;

三、使用Varnish实现网站动静分离
实验环境,三台虚拟机
Linux:CentOS6.5
Varnish:varnish-3.0.4-1.el6.x86_64
Nginx:nginx-1.4.7
Varnish主机:两块网卡,外网IP 172.16.36.10,内网IP 192.168.0.10
Web服务器1:IP 192.168.0.20,用于作静态文件服务器
Web服务器2:IP 192.168.0.30,用于作动态程序服务器

前提说明:
varnish
的配置文件为vcl后缀,位于/etc/varnish/目录,缓存通常用于提升响应速度,一般而言,可以缓存html静态页面、图片、js脚本、css
样式表,因为动态脚本语言编写的页面需要使用脚本引擎处理,因此没有缓存的必要性;nginx本身就有缓存及反向代理功能,完全可以实现web服务的动静
分离,不过以缓存功能作对比,varnish的缓存显然比nginx更专业,所以要作缓存服务器,可以试试varnish,本次操作将以实验性的目的,使
用varnish实现web服务动静分离;

1、安装Varnish

  1. rpm -ivh varnish-3.0.4-1.el6.x86_64.rpm varnish-docs-3.0.4-1.el6.x86_64.rpm varnish-libs-3.0.4-1.el6.x86_64.rpm

2、配置varnish
1)、编辑varnish脚本的配置文件/etc/sysconfig/varnish,将varnish监听的端口修改为80;

2)、新建文件/etc/varnish/web.vcl,编辑varnish缓存规则;
#定义后端服务器

  1. backend web1 {
  2. .host="192.168.0.20";
  3. .port="80";
  4. }
  5. backend web2 {
  6. .host="192.168.0.30";
  7. .port="80";
  8. }
  9. #只允许本机使用purgers请求方法清除缓存
  10. acl purgers {
  11. "127.0.0.1";
  12. "172.16.0.0"/16;
  13. }
  14. sub vcl_recv {
  15. if(req.request=="PURGE"){
  16. if(!client.ip~purgers) {
  17. error 405 "Mothod not allow";
  18. }
  19. }
  20. #静态资源交给web1服务器
  21. if(req.url ~ "\.(html|htm|shtml|css|js|jpg|png|gif|jpeg)"){
  22. set req.backend=web1;
  23. }
  24. #php页面交给web2服务器,并跳过缓存
  25. if(req.url ~ "\.php") {
  26. set req.backend=web2;
  27. return(pass);
  28. }
  29. return(lookup);
  30. }
  31. #将命中的缓存清除
  32. sub vcl_hit {
  33. if (req.request == "PURGE") {
  34. purge;
  35. error 200 "Purged OK";
  36. }
  37. }
  38. #如果请求清除的资源不在缓存列表中,返回404状态
  39. sub vcl_miss {
  40. if (req.request == "PURGE") {
  41. purge;
  42. error 404 "Not in cache";
  43. }
  44. }
  45. #如果请求清除的资源是一个不可缓存的资源,返回502状态
  46. sub vcl_pass {
  47. if (req.request == "PURGE") {
  48. error 502 "Purged on a passed object.";
  49. }
  50. }
  51. #缓存对象存活时间
  52. sub vcl_fetch {
  53. if(req.url ~ "\.(html|htm|shtml|css|js|jpg|png|gif|jpeg)"){
  54. set beresp.ttl=7200s;
  55. }
  56. }
  57. #将结果返回给客户端并在响应头部添加两字段,显示命中与否,并显示后端响应的web服务器
  58. sub vcl_deliver {
  59. if(obj.hits > 0) {
  60. set resp.http.X-Cache="HIT from" + " " + server.ip;
  61. }else{
  62. set resp.http.X-Cache="MISS";
  63. }
  64. set resp.http.Backend-IP=req.backend;
  65. }

3)、将配置加载至varnish;
3.1)、连接varnish;

3.2)、加载配置;

3.3)、使用配置;

4)、配置两台web服务器,分别安装nginx与php;
192.168.0.20服务器,新建两页面,index.html与index.php,两页面请求输出结果如下:

192.168.0.30服务器,新建两页面,index.html与index.php,两页面请求输出结果如下:


5)、测试结果,打开地址:172.16.36.10;
当我们请求html页面时,无论我们怎么刷新请求,缓存总是命中,并显示HIT,并且后端服务器一直是,web1(192.168.0.20);

当我们请求php页面时,我们不让他缓存,那么缓存也就永远不会命中,显示MISS,并且后端服务器一直是,web2(192.168.0.30);

6)、清除缓存;

整个配置完成,varnish实现了动静分离.

cnetos6.5安装Varnish的更多相关文章

  1. 安装Varnish 及遇到的坑

      转自:http://ixdba.blog.51cto.com/2895551/682555   一.安装Varnish Varnish的安装非常简单,下面逐步介绍: 1.安装前的准备  Varni ...

  2. linux环境下安装varnish

    Varnish是一款高性能的开源HTTP加速器,挪威最大的在线报纸 Verdens Gang 使用3台Varnish代替了原来的12台Squid,性能比以前更好. sudo apt-get insta ...

  3. 高性能HTTP加速器Varnish安装与配置

    导读 Varnish是一款高性能且开源的反向代理服务器和HTTP加速器,它采用了全新的软件体系结构,和现在的硬件体系配合紧密.下面就由我给大家简单说说他的安装与配置. 安装 安装pcre 如果没有安装 ...

  4. varnish缓存安装使用

    varnish PDF http://files.cnblogs.com/jimingsong/varnish.pdf 目前介绍CentOS6.4-64位系统 yum安装varnish: 配置varn ...

  5. 高性能HTTP加速器Varnish安装与配置(包含常见错误)

    Varnish是一款高性能的开源HTTP加速器.挪威最大的在线报纸Verdens Gang使用3台Varnish取代了原来的12台Squid,性能竟然比曾经更好.Varnish 的作者Poul-Hen ...

  6. Varnish快速安装及测试

    实验环境: slave-147:   192.168.75.147 slave-148:    192.168.75.148 两台机器均已关闭selinux,关闭iptables. varnish部署 ...

  7. linux centos 安装配置varnish

    安装2.0+版本 前期准备: 下载pcre http://sourceforge.net/projects/pcre/files/pcre/ http://optimate.dl.sourceforg ...

  8. Varnish 6.2.2 的介绍与安装

    一.简介 Varnish 是一款高性能且开源的反向代理服务器和 HTTP 加速器,其采用全新的软件体系机构,和现在的硬件体系紧密配合,与传统的 Squid 相比,Varnish 具有性能更高.速度更快 ...

  9. 学习varnish随笔

    Varnish是一款高性能.开源的反向代理服务器和缓存服务器.Varnish使用内存缓存文件来减少响应时间和网络带宽消耗.这个项目是由挪威的一家报纸Verdens Gang的网络分支起始的,其架构设计 ...

随机推荐

  1. 2019 UCloudjava面试笔试题 (含面试题解析)

      本人5年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.UCloud等公司offer,岗位是Java后端开发,因为发展原因最终选择去了UCloud,入职一年时间了,也 ...

  2. 自学Python编程的第四天----------来自苦逼的转行人

    2019-09-14 21:15:24 今天是学习Python的第四天,也是写博客的第四天 今天的内容是有关'列表'.'元组'.'range'的用法 列表:增删改查.列表的嵌套 元组:元组的嵌套 ra ...

  3. 一 python并发编程之多进程

    一 进程与程序 二 并发与并行 三 同步\异步和阻塞\非阻塞 四 进程的创建 五 进程的终止 六 进程的层次结构 七 进程的状态 八 进程并发的实现 一 进程与程序 什么是进程: 进程的概念:我们知道 ...

  4. 安装仪表盘控件Iocomp会遇到的几个常见问题

    相信从事HMI和自动化开发专业的小伙伴在使用工业仪表盘和图表控件时,都很熟悉怎么安装和操作Iocomp产品(毕竟它功能太强大了,基本人手一份的节奏),但是小编想肯定还是有很多和小编一样的入门的伙伴在安 ...

  5. Postgresql日志配置

    将PostgreSQL数据库安装后,需要进行一些关于数据库日志的配置,将postgresql.conf文件中,关于日志的配置选项详解,记录如下: 1.logging_collector = on/of ...

  6. Linux命令——mknode

    参考:What is the mknod command used for? 前言 Linux下面,一切皆文件,当然也包括设备.Linux通过major.minor号来区分不同设备,如下图

  7. 攻防世界WEB高手进阶之python_template_injection

    python模板注入 看了一堆文章,也不是看的很明白,反而把题目做出来了 大概思路如下 简单探测 http://111.198.29.45:42611/{{7+7}} 返回 说明服务器执行了{{}}里 ...

  8. java 的任意进制间转换

    直接上代码: public class Main { public static void main(String[] args) { // TODO Auto-generated method st ...

  9. Kotlin属性引用进阶与构造方法引用

    继续还是探讨Kotlin反射相关的知识点,说实话这块不是太好理解,待在实际工作中去对它进行实践慢慢来加深印象. 属性引用进阶: 在Kotlin中的反射其实是跟Java的反射有对应关系的,具体相关的定义 ...

  10. 微信小程序-数组操作

    Page({ data: { list:[{ id:, name:'芒果', count: },{ id:, name:'香蕉', count: }, }] } }) 向前插入数据 //要增加的数组 ...