阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Linux中Varnish基础应用

212次阅读
没有评论

共计 10051 个字符,预计需要花费 26 分钟才能阅读完成。

http  cache 的实现方式有两种:Squid、Varnish;一般被称为缓存服务器

Squid:支持正向和反向代理、是一款重量级的缓存服务器,在高负载的情况下,性能非常的稳定

Varnish:支持反向代理;相比于 Squid 是非常轻量级的缓存服务器,在高负载情况下,性能较差,没有 Squid 稳定;一般被称为 http 加速器;

Varnish 的特点:

一、组成部分

Management:作为主控进程;提供命令行接口、管理各种子进程、初始化,加载文件等等

Child/Cache:缓存管理、日志数据统计、接受用户请求、对所有缓存做有效性在验证,清理

VCL:Varnish 的配置语言;缓存控制机制,调用 C 编译器,生成二进制程序,让子进程加载

二、工作模式:

1、请求的资源可缓存:

(1)当客户端请求的资源命中了 Varnish 缓存且缓存未过期时,将直接响应给客户端;

(2)Varnish 作为一台反向代理缓存服务器,当客户端请求的资源未命中 Varnish 缓存时,Varnish 会扮演客户端角色去后端主机请求数据,将请求到的资源先缓存到本地,随后再将请求到的资源发送给客户端。

(3)当客户端请求的资源命中了 Varnish 缓存,但是 Varnish 上的缓存已过期时,则 Varnish 会去后端主机确认请求原始资源是否更新;如果未更新,则后端主机仅响应资源首部给 Varnish,随后 Varnish 再将响应资源发送给客户端;如果请求原始资源更新,则后端主机将会响应新的资源给 Varnish,Varnish 将响应的资源缓存在本地之后再响应给客户端;如果请求的资源后端主机已删除,则 Varnish 中的缓存也会被删除,响应给客户端 404 页面

2、请求的资源不可缓存:

(1)当客户端请求的资源为不可缓存时,Varnish 会直接去后端主机取得相应内容直接返回给客户端;而不是先缓存到本地再响应给客户端

衡量一个缓存的有效性:

缓存的命中率:

文档命中率:也称为资源命中率,从文档的个数进行衡量

字节命中率:从内容的大小进行衡量

缓存的生命周期:

缓存项过期:惰性清理

缓存空间用尽:使用 LRU 算法(最近最少使用算法)

注意:当一个缓存项过期时并不会真正从内存中青旅,只是标记为失效,而不是把它删除;当内存空间用尽时,才会真正的删除缓存项

 

三、缓存模式:

(1)file:缓存再磁盘的文件中,自行管理的关键系统

(2)malloc:内存缓存;使用 malloc()库调用,在 varnish 启动时向内存申请指定大小的空间进行缓存

(3)presistent:存储在磁盘上;

四、缓存新鲜度检测机制

有效性在验证:

如果原始内容发生改变,则仅响应首部(不用到 body 部分;响应码为 304(Not  Modified)

如果原始内容发生了改变,则正常响应给客户端,响应码为 200

如果原始内容消失,则响应 404,此时缓存中的缓存项(object)也应该被删除

条件式请求首部:

If-Modified_Since:基于原始内容的最近一个修改的时间戳进行验证

If-Ummodified_since:如果缓存发生了改变,响应 304

If-Match:基于请求内容的匹配做验证

If-None_match:基于 Etag 比较进行内容验证

五、缓存控制机制

过期日期:

  HTTP/1.0 Expires:给与的是绝对时长

    例如:Expires:Thu, 04 Jun 2015 23:38:18 GMT

  HTTP/1.1 Cache-Control: max-age 给与的是相对时长,从接受到相应报文开始

  例如:Cache-Control:max-age=700

六、VCL 相关的状态引擎

vcl_recv:接受请求

vcl_hash:

hit:vcl_hit:命中缓存

miss:vcl_miss:未命中缓存

purge:vcl_purge:清除缓存

pipe:vcl_pipe:管道;直接发送给后端主机

pass、hit_for_pass:vcl_pass  ## 跳过,直接请求后端主机

vcl_backend_fetch:读取数据

vcl_backend_response:后端主机响应

vcl_backend_error:后端主机响应错误码

vcl_synth:同步

vcl_deliver:响应给客户端

七、VCL 的语法格式

(1)表示注释://、#、/*……*/

(2)定义子例程

(3)不支持循环、支持条件判断

(4)具有内建变量

(5)使用终止语句 return,没有返回值

(6)支持操作符:=、==、!=、&&、||

八、VCl 内建变量

req.*:只匹配客户端发来的请求

    req.http.*:匹配 http 请求报文的任何首部

    bereq.*:由 varnish 向后端主机发出 http 请求

    beresp.*:由后端主机发来 http 的响应报文首部

    resp.*:由 varnish 响应给客户端的 http 的响应报文

    obj.*:存储在缓存空间中的缓存的对应属性

    常用的变量:

    berep:varnish 向后端主机请求资源

    bereq.request:请求方法(向后端主机发送请求报文)

    bereq.url:请求的 url

    bereq.proto:请求协议

    bereq.backend:指明要调用的后端主机是那个

    beresp:后端主机向 varnish 响应资源

    beresp.proto:响应协议

    beresp.status:响应的状态码

    beresp.reason:响应原因

    beresp.backend.name:后端主机名称

    beresp.ttl:后端主机请求中的内容的余下的生存时长     

     

    obj.hits:此对象从缓存中命中的次数

    obj.ttl:对象的 ttl 值;也被称为缓存时长

       

准备环境:CentOS  7

Varnish 服务器 IP:172.18.42.200
后端主机 1:提供 httpd 服务 IP:172.18.42.201
后端主机 2:提供 httpd 服务 IP:172.18.42.202

缓存服务器 Varnish 概念篇 http://www.linuxidc.com/Linux/2014-05/101389.htm

缓存服务器 Varnish 概念篇 http://www.linuxidc.com/Linux/2014-05/101389.htm

Varnish Cache 的架构笔记 http://www.linuxidc.com/Linux/2013-10/91016.htm

CentOS 5.8 下 Varnish-2.1.5 的安装配置 http://www.linuxidc.com/Linux/2013-09/89916.htm

RedHat 脚本改用 CentOS 源更新安装 Nginx、PHP 5.3、Varnish http://www.linuxidc.com/Linux/2012-07/65801.htm

利用 Varnish 构建 Cache 服务器笔记 http://www.linuxidc.com/Linux/2012-07/65234.htm

缓存服务 Varnish 安装配置 http://www.linuxidc.com/Linux/2012-07/65228.htm

Varnish 编译安装所需准备 http://www.linuxidc.com/Linux/2012-07/65230.htm

Linux 下 Varnish 缓存的配置优化 http://www.linuxidc.com/Linux/2012-03/56435.htm

一、Varnish 服务器配置

1、安装 varnish

1
2
3
4
5
6
7
8
[root@node0 ~]# yum install varnish
[root@node0 ~]# ll /etc/varnish/
total 20
-rw-r--r-- 1 root root 1155 May 20 17:07 default.vcl  ## 配置 Varnish 缓存策略
-rw-r--r-- 1 root root 1224 May 20 11:10 default.vcl.wtc
-rw------- 1 root root   37 May 20 11:09 secret
-rw-r--r-- 1 root root 1200 Mar 16  2015 varnish.params   ## 配置缓存机制
-rw-r--r-- 1 root root 1200 May 20 11:12 varnish.params.bak

2、更改 varnish 的缓存模式:

1
2
3
[root@node0 varnish]# vim varnish.params   
#VARNISH_STORAGE="file,/var/lib/varnish/varnish_storage.bin,1G"  ## 默认的缓存机制
VARNISH_STORAGE="malloc,1G"   ## 更改缓存为 malloc 模式

3、定义后端主机

1
2
3
4
5
[root@node0 varnish]# vim default.vcl  ##
backend default {
    .host = "172.18.42.202";    ## 后端主机 1
    .port = "80";    ##web80 端口
}

二、配置后端主机

1、后端主机 1 安装 httpd、php

1
2
[root@node1 ~]# yum install httpd -y
[root@node1 html]# systemctl start httpd.service

2、后端主机 2 安装 httpd

1
2
[root@node2 ~]# yum install nginx
[root@node2 nginx]# nginx

更多详情见请继续阅读下一页的精彩内容 :http://www.linuxidc.com/Linux/2016-08/134025p2.htm

三、配置 default.vcl 缓存策略

1、当请求资源可缓存时,查看缓存是否命中

1
2
3
4
5
6
7
8
sub vcl_deliver {
if (obj.hits>0) {
        set resp.http.X-Cache = "HIT";
    }
    else {
        set resp.http.X-Cache = "MISS";
    }
}    ## 如果请求的资源未命中则显示 MISS、命中则显示 HIT

第一次请求:

Linux 中 Varnish 基础应用

第二次请求:命中了 varnish 缓存

Linux 中 Varnish 基础应用

2、强制对某些资源不检查缓存

1
2
3
4
5
6
7
[root@node2 ~]# mkdir /web/lweim/wtc   ## 在后端主机新目录“wtc”
[root@node2 ~]# vim  /web/lweim/wtc/index.html   
sub vcl_recv {
if (req.url ~ "(?i)^/wtc") {
        return(pass);
    }
}    ## 当请求的 url 当中有“wtc”时,则不会去命中缓存,而是直接由 varnish 请求后端主机

第一次请求:

Linux 中 Varnish 基础应用

第二次请求:

Linux 中 Varnish 基础应用

3、定义多台后端主机

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
backend  web2 {
    .host = "172.18.42.202";
    .port = "80";
}
backend web1 {
    .host = "172.18.42.201";
    .port = "80";
}
sub vcl_recv {
    if (req.url ~ "(?i)\.php$") {
        set req.backend_hint = web1;   ## 当请求 url 中有 php 时,则是后端主机 web1 来响应
                return(pass);
    }
    else {
        set req.backend_hint = web2;   ##url 中没有 php 的请求都由后端主机 web2 来响应
                return(pass);
    }
}

第一次请求静态资源

Linux 中 Varnish 基础应用

第二次请求 php

Linux 中 Varnish 基础应用

4、实现负载均衡

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import directors;    ## 定义一个主机组
  
backend web1 {## 定义第一个后端服务器
    .host = "172.18.42.201";
    .port = "80";
}
  
backend  web2 {## 定义第二个后端服务器
    .host = "172.18.42.202";
    .port = "80";
}
  
sub vcl_init {## 定义一个服务器组
    new web = directors.round_robin();
    web.add_backend(web1);
    web.add_backend(web2);
}
sub vcl_recv {
    if (req.url ~ "(?i)^/wtc") {
        set req.backend_hint = web.backend();
        return(pass);  ## 直接请求后端主机服务器
     }
}

第一次请求:

Linux 中 Varnish 基础应用

第二次请求:

Linux 中 Varnish 基础应用

5、对后端主机做健康检测

1
2
3
4
5
6
7
8
9
10
backend web1 {
    .host = "172.18.42.201";
    .port = "80";
    .probe = {
        .url = "/";
        .interval = 1s;  ## 每隔多长时间检测一次
        .window = 8;     ## 指定后端主机要检测多少次
        .threshold 5;    ## 指定至少要有几次是检测成功的
        .timeout 2s;     ## 指定检测时间的超时时长;默认为 2s
}

6、修改 varnish 运行时命令参数

1
2
3
4
5
6
7
[root@node0 varnish]# varnishstat
MAIN.pools                          4         0.00          .           4.00
[root@node0 ~]# varnishadm -S /etc/varnish/secret -T 127.0.0.1:6082
param.set thread_pools 2
200      ## 响应码为 200 即为修改成功
[root@node0 varnish]# varnishstat
MAIN.pools                          2         0.00          .           2.00

7、查看 varnish 的工作状态及其相关信息

1
[root@node0 varnish]# varnishstat

Linux 中 Varnish 基础应用

Varnish 的详细介绍 :请点这里
Varnish 的下载地址 :请点这里

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2016-08/134025.htm

http  cache 的实现方式有两种:Squid、Varnish;一般被称为缓存服务器

Squid:支持正向和反向代理、是一款重量级的缓存服务器,在高负载的情况下,性能非常的稳定

Varnish:支持反向代理;相比于 Squid 是非常轻量级的缓存服务器,在高负载情况下,性能较差,没有 Squid 稳定;一般被称为 http 加速器;

Varnish 的特点:

一、组成部分

Management:作为主控进程;提供命令行接口、管理各种子进程、初始化,加载文件等等

Child/Cache:缓存管理、日志数据统计、接受用户请求、对所有缓存做有效性在验证,清理

VCL:Varnish 的配置语言;缓存控制机制,调用 C 编译器,生成二进制程序,让子进程加载

二、工作模式:

1、请求的资源可缓存:

(1)当客户端请求的资源命中了 Varnish 缓存且缓存未过期时,将直接响应给客户端;

(2)Varnish 作为一台反向代理缓存服务器,当客户端请求的资源未命中 Varnish 缓存时,Varnish 会扮演客户端角色去后端主机请求数据,将请求到的资源先缓存到本地,随后再将请求到的资源发送给客户端。

(3)当客户端请求的资源命中了 Varnish 缓存,但是 Varnish 上的缓存已过期时,则 Varnish 会去后端主机确认请求原始资源是否更新;如果未更新,则后端主机仅响应资源首部给 Varnish,随后 Varnish 再将响应资源发送给客户端;如果请求原始资源更新,则后端主机将会响应新的资源给 Varnish,Varnish 将响应的资源缓存在本地之后再响应给客户端;如果请求的资源后端主机已删除,则 Varnish 中的缓存也会被删除,响应给客户端 404 页面

2、请求的资源不可缓存:

(1)当客户端请求的资源为不可缓存时,Varnish 会直接去后端主机取得相应内容直接返回给客户端;而不是先缓存到本地再响应给客户端

衡量一个缓存的有效性:

缓存的命中率:

文档命中率:也称为资源命中率,从文档的个数进行衡量

字节命中率:从内容的大小进行衡量

缓存的生命周期:

缓存项过期:惰性清理

缓存空间用尽:使用 LRU 算法(最近最少使用算法)

注意:当一个缓存项过期时并不会真正从内存中青旅,只是标记为失效,而不是把它删除;当内存空间用尽时,才会真正的删除缓存项

 

三、缓存模式:

(1)file:缓存再磁盘的文件中,自行管理的关键系统

(2)malloc:内存缓存;使用 malloc()库调用,在 varnish 启动时向内存申请指定大小的空间进行缓存

(3)presistent:存储在磁盘上;

四、缓存新鲜度检测机制

有效性在验证:

如果原始内容发生改变,则仅响应首部(不用到 body 部分;响应码为 304(Not  Modified)

如果原始内容发生了改变,则正常响应给客户端,响应码为 200

如果原始内容消失,则响应 404,此时缓存中的缓存项(object)也应该被删除

条件式请求首部:

If-Modified_Since:基于原始内容的最近一个修改的时间戳进行验证

If-Ummodified_since:如果缓存发生了改变,响应 304

If-Match:基于请求内容的匹配做验证

If-None_match:基于 Etag 比较进行内容验证

五、缓存控制机制

过期日期:

  HTTP/1.0 Expires:给与的是绝对时长

    例如:Expires:Thu, 04 Jun 2015 23:38:18 GMT

  HTTP/1.1 Cache-Control: max-age 给与的是相对时长,从接受到相应报文开始

  例如:Cache-Control:max-age=700

六、VCL 相关的状态引擎

vcl_recv:接受请求

vcl_hash:

hit:vcl_hit:命中缓存

miss:vcl_miss:未命中缓存

purge:vcl_purge:清除缓存

pipe:vcl_pipe:管道;直接发送给后端主机

pass、hit_for_pass:vcl_pass  ## 跳过,直接请求后端主机

vcl_backend_fetch:读取数据

vcl_backend_response:后端主机响应

vcl_backend_error:后端主机响应错误码

vcl_synth:同步

vcl_deliver:响应给客户端

七、VCL 的语法格式

(1)表示注释://、#、/*……*/

(2)定义子例程

(3)不支持循环、支持条件判断

(4)具有内建变量

(5)使用终止语句 return,没有返回值

(6)支持操作符:=、==、!=、&&、||

八、VCl 内建变量

req.*:只匹配客户端发来的请求

    req.http.*:匹配 http 请求报文的任何首部

    bereq.*:由 varnish 向后端主机发出 http 请求

    beresp.*:由后端主机发来 http 的响应报文首部

    resp.*:由 varnish 响应给客户端的 http 的响应报文

    obj.*:存储在缓存空间中的缓存的对应属性

    常用的变量:

    berep:varnish 向后端主机请求资源

    bereq.request:请求方法(向后端主机发送请求报文)

    bereq.url:请求的 url

    bereq.proto:请求协议

    bereq.backend:指明要调用的后端主机是那个

    beresp:后端主机向 varnish 响应资源

    beresp.proto:响应协议

    beresp.status:响应的状态码

    beresp.reason:响应原因

    beresp.backend.name:后端主机名称

    beresp.ttl:后端主机请求中的内容的余下的生存时长     

     

    obj.hits:此对象从缓存中命中的次数

    obj.ttl:对象的 ttl 值;也被称为缓存时长

       

准备环境:CentOS  7

Varnish 服务器 IP:172.18.42.200
后端主机 1:提供 httpd 服务 IP:172.18.42.201
后端主机 2:提供 httpd 服务 IP:172.18.42.202

缓存服务器 Varnish 概念篇 http://www.linuxidc.com/Linux/2014-05/101389.htm

缓存服务器 Varnish 概念篇 http://www.linuxidc.com/Linux/2014-05/101389.htm

Varnish Cache 的架构笔记 http://www.linuxidc.com/Linux/2013-10/91016.htm

CentOS 5.8 下 Varnish-2.1.5 的安装配置 http://www.linuxidc.com/Linux/2013-09/89916.htm

RedHat 脚本改用 CentOS 源更新安装 Nginx、PHP 5.3、Varnish http://www.linuxidc.com/Linux/2012-07/65801.htm

利用 Varnish 构建 Cache 服务器笔记 http://www.linuxidc.com/Linux/2012-07/65234.htm

缓存服务 Varnish 安装配置 http://www.linuxidc.com/Linux/2012-07/65228.htm

Varnish 编译安装所需准备 http://www.linuxidc.com/Linux/2012-07/65230.htm

Linux 下 Varnish 缓存的配置优化 http://www.linuxidc.com/Linux/2012-03/56435.htm

一、Varnish 服务器配置

1、安装 varnish

1
2
3
4
5
6
7
8
[root@node0 ~]# yum install varnish
[root@node0 ~]# ll /etc/varnish/
total 20
-rw-r--r-- 1 root root 1155 May 20 17:07 default.vcl  ## 配置 Varnish 缓存策略
-rw-r--r-- 1 root root 1224 May 20 11:10 default.vcl.wtc
-rw------- 1 root root   37 May 20 11:09 secret
-rw-r--r-- 1 root root 1200 Mar 16  2015 varnish.params   ## 配置缓存机制
-rw-r--r-- 1 root root 1200 May 20 11:12 varnish.params.bak

2、更改 varnish 的缓存模式:

1
2
3
[root@node0 varnish]# vim varnish.params   
#VARNISH_STORAGE="file,/var/lib/varnish/varnish_storage.bin,1G"  ## 默认的缓存机制
VARNISH_STORAGE="malloc,1G"   ## 更改缓存为 malloc 模式

3、定义后端主机

1
2
3
4
5
[root@node0 varnish]# vim default.vcl  ##
backend default {
    .host = "172.18.42.202";    ## 后端主机 1
    .port = "80";    ##web80 端口
}

二、配置后端主机

1、后端主机 1 安装 httpd、php

1
2
[root@node1 ~]# yum install httpd -y
[root@node1 html]# systemctl start httpd.service

2、后端主机 2 安装 httpd

1
2
[root@node2 ~]# yum install nginx
[root@node2 nginx]# nginx

更多详情见请继续阅读下一页的精彩内容 :http://www.linuxidc.com/Linux/2016-08/134025p2.htm

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计10051字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中