有博友反应说gravatar服务器访问不了或过慢,导致访问我的网站有时因为加载原因而缓慢。
所以将gravatar反向代理一下。常见的有nginx反代,不过不在本章讨论范围。
注意,本章内容仅适用于varnish3,首先创建backend,如下:
backend avatarserver {
.host = 192.0.80.240;
.port = 80;
}这个192.0.80.240的ip怎么来的呢?
是通过dig gravatar.com而来的,gravatar有多个ip实现均衡负载,但varnish3只支持解析一个ip,所以如果以:
backend avatarserver {
.host = gravatar.com;
.port = 80;
}那么varnish会提示让你选择一个ip,导致启动varnish失败。
但众所皆知,gravatar毕竟是主服务器,即便是美国服务器,连接gravatar也由
如果通过二级域名,如www、1、2、3、4···等可以直接使用cdn服务,获得更好更快的服务器来响应。
但不幸的是,cdn是认域名来判断你是否有权限来解析的。而且cdn也有不同ip。所以也无法单纯通过下面两个例子来解析:
backend avatarserver {
.host = www.gravatar.com;
.port = 80;
}
##直接是在启动varnish时,提示让你选择一个ip,失败。
backend avatarserver {
.host = 68.232.44.121;
.port = 80;
}
##启动varnish,解析正常,cdn获得的是你的域名解析了该ip,而你在cdn运营商服务列表是不存在的,他会返回404给你,失败。所以,只能选择主域名的其中一个ip来作为varnish反代的对象。好在gravatar是允许直接进行ip访问的,直接省了不少事。
接着,在sub vcl_recv添加:
if (req.http.host ~ ^(avatar.kn007.net)$){
if (req.http.referer ~ kn007.net){
set req.backend = avatarserver;
} else {
error 403 access denied;
}
}这样的意义就是判断referer即来源是不是来自我们的博客主域名,如果是允许访问,一种防盗链的办法。
最后在sub vcl_fetch设置缓存过期时间,比如说一天?
set beresp.ttl = 24h如此便完成了varnish对gravatar的反代。
那么wordpress如何去使用,或者说自动替换原始gravatar的地址,为我们的反代地址呢?
可以利用wp的hook钩子,在functions.php添加如下代码,正则写的比较粗,没什么心情主要,反正能用就算了。
function setting_get_avatar($avatar) {
$avatar = preg_replace(#(http|https):\/\/.*?\.gravatar.com#i,http://avatar.kn007.net,$avatar);
return $avatar;
}
add_filter( 'get_avatar', 'setting_get_avatar', 1 );不过你得保证get_avatar没被hook过,要不就要改下优先级,或者合并函数。
教材到此结束,上班。
ps:再次提醒一下,博客准备重新备案。随时可能闭站,谢谢。。。
另外已将google的favicon也添加到反代缓存。
转载请注明转自:kn007的个人博客的《varnish 3 反向代理 gravatar 服务器》
