VCL
vcl常用配置
不缓存摸一个资源
在vcl_recv中
if (req.url ~ "private") {
return (pass);
}
动静分离
先定一个多个backend
backend defualt {
.host = "192.168.1.56";
.port = "80";
}
backend websrv {
.host = "192.168.1.58";
.port = "80";
}
在vcl_recv中
if (rep.url ~ "\.php$") {
set req.backend_hint = websrv;
} else {
set req.backend_hint = default;
}
配置虚拟主机
在vcl_recv中配置
if (rep.http.host ~ "www.bux.com") {
set req.backend_hint = websrv;
}
if (rep.http.host ~ "ftp.bux.com") {
set req.backend_hint = default;
}
此时缓存是否命中
在deliver中配置, deliver就是将Server(Cache 服务器, 就是varnish)的相应报文发送给客户端
// 如果命中
if (obj.hits > 0) {
set resp.http.Is-Hit = "Hit";
} else {
set resp.http.Is-Hit = "Miss";
}
将cookie绑定的私有缓存转为共有缓存
在vcl_backend_response中
if (beresp.http.cache-control !~ "s-maxage") { // s-maxage表示共有缓存, 此时报文应该没有Set-Cookie字段
if (bereq.url ~ "\.jpg$") { // 如果请求的是图片就将其定义公共缓存到缓存服务器上
beresp.ttl = 3500s;
unset beresp.http.Set-Cookie;
}
}
健康检测
backend websrv {
.host = "192.168.1.56";
.port = "80";
.probe = {
.url = "http://192.168.1.59/test.html";
}
}
配置拒绝请求
在vcl_recv中
if (req.http.host ~ "ftp.bux.com") {
return (synth(405));
}
生产中一定要配置purge(清理缓存), 但是只能是机房中的, 同时对于miss的应该返回error 405 "Not in cache", 因为miss就表示这该资源不在缓存中, 无法清理
acl purgers {
"127.0.0.1"/8;
"192.168.1.0/24";
}
sub vcl_recv {
if (req.request == "PURGE") { // 客户端请求清理缓存
// 一定要有这个if, 防止其他主机随意修改
if (!client.ip ~ purgers) { // 如果不在acl中的主机请求清理则拒绝
return (pass);
}
return(purge);
}
}
curl发送PURGE请求方法, curl -X PURGE url
搭建集群
import directors;
sub vcl_init {
new cluster1 = directors.round_robin();
cluster1.add_backend(websrv1);
cluster1.add_backend(websrv2);
}
sub vcl_recv {
set req.backend_hint = cluster1.backend();
}
VCL的更多相关文章
- DevExpress VCL v16.1.3发布
ExpressPDFViewer # BC3840:包含action标题和action提示的 Action classes 和 resource strings 重命名: class名称末尾中包含'A ...
- 转:看看 Delphi XE2 为 VCL 提供的 14 种样式
http://www.linuxso.com/linuxbiancheng/8889.html 其实只提供了 个 vsf 样式文件, 还有默认的 Windows 样式, 共 种. 在空白窗体上添加 L ...
- Delphi:与VCL同步(Synchronize()、用消息来同步)
看本文时,可以同时参考:Delphi中线程类 TThread实现多线程编程(事件.临界区.Synchronize.WaitFor……) 先说一下RTL和VCL RTL(Run-Time library ...
- varnish4.1 配置文件default.vcl
varnish4.1 配置文件default.vcl # This .x VCL file vcl 4.0; backend default { .host = "127.0.0.1&quo ...
- 【温故Delphi】之VCL消息机制小结
TObject消息分派 procedure Dispatch(var Message); virtual; #负责分派消息到特定VCL组件的事件处理函数 procedure DefaultHandle ...
- DevExpress VCL 13.1.4支持Delphi /C++Builder XE5
DevExpress VCL 13.1.4支持Delphi /C++Builder XE5 重大变化 ExpressLibrary dxHalfOfPi常数声明已经从cxGeometry单元移到了cx ...
- Devexpress VCL Build v2014 vol 15.2.3 发布
2016年第一个版本,继续修补. New Major Features in 15.2 What's New in VCL Products 15.2 Breaking Changes To lear ...
- Devexpress VCL Build v2015 vol 15.2 开始测试
增加了几个小玩意,与大版本变化根本无法匹配. 具体可以官网了解 https://www.devexpress.com/Subscriptions/New-2015.xml?product=vcl
- Delphi的VCL组件库
Visual Component Library的缩写(可视组件库)VCL是Visual Component Library的缩写,即可视组件库,它是Delphi,C++Builder等编程语言的基本 ...
- 在XE5中 VCL空窗体的3个线程
中午看到技术群里有人讨论, XE5一个空窗体程序就包含了3个线程, 赶忙打开XE5开了个空窗体一看, 果然如此 再打开D7和2010看了一下, 都是一个线程 这时看到有人说一个是输入法, 一个是GDI ...
随机推荐
- 通过委托更新UI(异步加载)
来自:http://blog.csdn.net/gongzhe2011/article/details/27351853 using System.Windows.Forms; using Syste ...
- ubuntu - 安装sqoop
解析过程 参考:https://www.cnblogs.com/qingyunzong/p/8807252.html#_label4 一.下载 二.解压到指定目录 三.配置sqoop环境变量并生效 四 ...
- CSS选择器及CSS样式表
前言 牛腩新闻发布系统中记忆最深的就是各种CSS选择器各种CSS样式,这些选择器之间肯定有它的优先级,包括CSS样式也一样,也是有它的优先级,本文介绍一些各种CSS选择器各种CSS样式以及它们的优先级 ...
- MongoDB初识篇
前言 一直听说MongonDB,却没有机会接触它,于是决定先从表面上认识它.MongoDB(分布式文档存储数据库)是一种介于关系型数据库和非关系型数据库之间的数据库,而且它是非关系数据库中最像关系型数 ...
- phaser小游戏框架学习(一)
这两天由于项目的需要,所以简单学了一下phaser框架. 官网:http://phaser.io/ 还有一个phaser小站,是中文的网站,但是内容不如英文文档全,大家也可以去看这个网站,需要查阅AP ...
- Pre- and Post-order Traversals(先序+后序序列,建立二叉树)
PAT甲级1119,我先在CSDN上面发布的这篇文章:https://blog.csdn.net/weixin_44385565/article/details/89737224 Suppose th ...
- C语言中存储类别、链接与内存管理
第12章 存储类别.链接和内存管理 通过内存管理系统指定变量的作用域和生命周期,实现对程序的控制.合理使用内存是程序设计的一个要点. 12.1 存储类别 C提供了多种不同的模型和存储类别,在内存中 ...
- HDU-Big Number (斯特林公式)
In many applications very large integers numbers are required. Some of these applications are using ...
- 网络流之最大流与最小费用流入门&&模板
理解处 刷题处 模板处 最大流模板 处理重边的+(优化) #include<bits/stdc++.h> using namespace std; ; const int INF = 0x ...
- Hie with the Pie(状压DP+可以经过多次相同的点要全部走过的最短回路)
大意:一个人要送n份货,给出一个矩阵,表示任意两个点间的直接路径长度,求从起点0送完这n份货(到达指定的n个地点)再回到起点0的最短时间.经过任意顶点的次数不限. 分析:既然是可以过多个点,那我们可以 ...