手动 4- linux配置varnish

2024-03-25 13:32
文章标签 配置 linux 手动 varnish

本文主要是介绍手动 4- linux配置varnish,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#############################################

centos 6 快速安装:

rpm --nosignature -i http://repo.varnish-cache.org/redhat/varnish-3.0/el6/noarch/varnish-release/varnish-release-3.0-1.el6.noarch.rpm

yum install varnish

#############################################

安装完成magento后,需要安装varnish


安装varnish:

1.
安装环境,其他软件,varnish需要这些软件的支持。
yum install -y automake autoconf libtool ncurses-devel libxslt groff pcre-devel pkgconfig  libedit*


2.
wget http://jaist.dl.sourceforge.net/project/pcre/pcre/8.34/pcre-8.34.zip


手动下载地址:http://sourceforge.net/projects/pcre/files/pcre/
安装pcre
unzip -o pcre-8.34.zip
cd pcre-8.34
./configure --prefix=/usr/local/pcre/
make
make install


3
安装varnish
wget http://repo.varnish-cache.org/source/varnish-3.0.4.tar.gz
tar zxvf varnish-3.0.4.tar.gz
cd varnish-3.0.4
export PKG_CONFIG_PATH=/usr/local/pcre/lib/pkgconfig/
./configure --prefix=/usr/local/varnish --enable-dependency-tracking --enable-debugging-symbols --enable-developer-warnings
make
make install
cp redhat/varnish.initrc  /etc/init.d/varnish  --varnish的启动脚本
cp redhat/varnish.sysconfig  /etc/sysconfig/varnish  --varnish配置文件
cp redhat/varnish_reload_vcl /usr/local/varnish/bin/ --此文件用于修改配置文件后重新加载,这样避免重启造成已缓存文件丢失



编辑文件:

vim  /etc/sysconfig/varnish

#Configuration file for varnish
#
# /etc/init.d/varnish expects the variable $DAEMON_OPTS to be set from this
# shell script fragment.
## Maximum number of open files (for ulimit -n)
NFILES=131072# Locked shared memory (for ulimit -l)
# Default log size is 82MB + header
MEMLOCK=82000# Maximum size of corefile (for ulimit -c). Default in Fedora is 0
# DAEMON_COREFILE_LIMIT="unlimited"# Set this to 1 to make init script reload try to switch vcl without restart.
# To make this work, you need to set the following variables
# explicit: VARNISH_VCL_CONF, VARNISH_ADMIN_LISTEN_ADDRESS,
# VARNISH_ADMIN_LISTEN_PORT, VARNISH_SECRET_FILE, or in short,
# use Alternative 3, Advanced configuration, below
RELOAD_VCL=1# This file contains 4 alternatives, please use only one.## Alternative 1, Minimal configuration, no VCL
#
# Listen on port 6081, administration on localhost:6082, and forward to
# content server on localhost:8080. Use a fixed-size cache file.
#
#DAEMON_OPTS="-a :80 \
# -T 173.193.39.186:2000 \
# -u varnish -g varnish \
# -s file,/data/varnish/cache/varnish_cache.data,80G"
# -f /usr/local/varnish/etc/varnish/default.vcl## Alternative 2, Configuration with VCL
#
# Listen on port 6081, administration on localhost:6082, and forward to
# one content server selected by the vcl file, based on the request. Use a
# fixed-size cache file.
#
#DAEMON_OPTS="-a :6081 \
# -T localhost:6082 \
# -f /etc/varnish/default.vcl \
# -u varnish -g varnish \
# -S /etc/varnish/secret \
# -s file,/var/lib/varnish/varnish_storage.bin,1G"## Alternative 3, Advanced configuration
#
# See varnishd(1) for more information.
#
# 配置文件路径: # Main configuration file. You probably want to change it :)
VARNISH_VCL_CONF=/usr/local/varnish/etc/varnish/default.vcl
#
# # Default address and port to bind to
# # Blank address means all IPv4 and IPv6 interfaces, otherwise specify
# # a host name, an IPv4 dotted quad, or an IPv6 address in brackets.
# 默认监听端口:VARNISH_LISTEN_ADDRESS=
VARNISH_LISTEN_PORT=80
#
# 后台端口# Telnet admin interface listen address and port
VARNISH_ADMIN_LISTEN_ADDRESS=173.193.39.187
VARNISH_ADMIN_LISTEN_PORT=6088
#
# secrest 文件路径# Shared secret file for admin interface
VARNISH_SECRET_FILE=/usr/local/varnish/etc/varnish/secret
#
# # The minimum number of worker threads to start
VARNISH_MIN_THREADS=50
#
# # The Maximum number of worker threads to start
VARNISH_MAX_THREADS=1000
#
# # Idle timeout for worker threads
VARNISH_THREAD_TIMEOUT=120
#
# # Cache file location
# varnish 文件路径 VARNISH_STORAGE_FILE=/var/lib/varnish/varnish_storage.bin
VARNISH_STORAGE_FILE=/data/varnish/cache/varnish_cache.data
#
# # Cache file size: in bytes, optionally using k / M / G / T suffix,
# varnish分配的内存 # or in percentage of available disk space using the % suffix.
VARNISH_STORAGE_SIZE=6G
#
# # Backend storage specification
VARNISH_STORAGE="file,${VARNISH_STORAGE_FILE},${VARNISH_STORAGE_SIZE}"
#
# 过期时间 # Default TTL used when the backend does not specify one
VARNISH_TTL=864000000
#
# # DAEMON_OPTS is used by the init script. If you add or remove options, make
# # sure you update this section, too.
DAEMON_OPTS="-a ${VARNISH_LISTEN_ADDRESS}:${VARNISH_LISTEN_PORT} \
-f ${VARNISH_VCL_CONF} \
-T ${VARNISH_ADMIN_LISTEN_ADDRESS}:${VARNISH_ADMIN_LISTEN_PORT} \
-t ${VARNISH_TTL} \
-w ${VARNISH_MIN_THREADS},${VARNISH_MAX_THREADS},${VARNISH_THREAD_TIMEOUT} \
-u varnish -g varnish \
-S ${VARNISH_SECRET_FILE} \
-s ${VARNISH_STORAGE}"
### Alternative 4, Do It Yourself. See varnishd(1) for more information.
#
# DAEMON_OPTS=""

上面的配置文件,复制后注意后面的空格,譬如:-w ${VARNISH_MIN_THREADS},${VARNISH_MAX_THREADS},${VARNISH_THREAD_TIMEOUT} \   ,后面有空格会报错

如果您想用内存,而不想用磁盘,那么 

-s malloc,4G

那么把


-s ${VARNISH_STORAGE

改为上面

注意:

上面需要修改的为:VARNISH_ADMIN_LISTEN_ADDRESS 改为当前ip
VARNISH_STORAGE_SIZE=6G  按照您的需要改
VARNISH_TTL= 按照您的需要过期时间



/usr/local/varnish/etc/varnish/default.vcl:

include "include/header.vcl";
include "include/footer.vcl";

/usr/local/varnish/etc/varnish/include/header.vcl:
backend default {.host = "127.0.0.1";.port = "6081";.connect_timeout = 6000s;.first_byte_timeout = 6000s;.between_bytes_timeout = 6000s;
}backend weike {.host = "www.tomorrowtop.net";.port = "6001";
}backend phpmyadmin {.host = "173.192.59.7";.port = "6002";
}backend nagios {.host = "173.192.59.2";.port = "6003";
}backend faspeed {.host = "www.faspeed.com";.port = "6004";
}backend tomtopblog {.host = "blog.tomtop.com";.port = "6004";
}backend tomtopcnblog {.host = "cnblog.tomtop.com";.port = "6004";
}#acl purge {
#   "10.12.167.130";
#}sub vcl_recv {#如果host为www.example.com,设置后端服务器为www,(?i)表示匹配模式为不区分大小写if (req.http.host ~ "(?i)^(img2.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-auction.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-au.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-game.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-shop.)?tomtop.com$"|| req.http.host ~ "(?i)^(homegarden2012.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-sales.)?tomtop.com$"|| req.http.host ~ "(?i)^(usbempire.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-home.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-digital.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-wholesaler.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-w.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-uk.)?tomtop.com$"|| req.http.host ~ "(?i)^(antiquechina2009.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-deals.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomorrowhome.)?tomtop.com$"|| req.http.host ~ "(?i)^(ttmallzone365.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomorrowtop.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-usa.)?tomtop.com$"|| req.http.host ~ "(?i)^(ttstoreusa.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomtop-mall.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomorrowyes.)?tomtop.com$"|| req.http.host ~ "(?i)^(costcobuy.)?tomtop.com$"|| req.http.host ~ "(?i)^(tomorrowokla.)?tomtop.com$"|| req.http.host ~ "(?i)^(addstore.)?tomtop.com$"|| req.http.host ~ "(?i)^(newgaga.)?tomtop.com$"|| req.http.host ~ "(?i)^(newmango.)?tomtop.com$"|| req.http.host ~ "(?i)^(lalayes.)?tomtop.com$"|| req.http.host ~ "(?i)^(dudustory.)?tomtop.com$"|| req.http.host ~ "(?i)^(buyonline315.)?tomtop.com$"|| req.http.host ~ "(?i)^(bluebetter.)?tomtop.com$"|| req.http.host ~ "(?i)^(tootooup.)?tomtop.com$"|| req.http.host ~ "(?i)^(ilastone.)?tomtop.com$"|| req.http.host ~ "(?i)^(kokoyesgo.)?tomtop.com$"|| req.http.host ~ "(?i)^(anforme.)?tomtop.com$"|| req.http.host ~ "(?i)^(smartlife2013.)?tomtop.com$"|| req.http.host ~ "(?i)^(dodotech.)?tomtop.com$"|| req.http.host ~ "(?i)^(7colorstore.)?tomtop.com$"|| req.http.host ~ "(?i)^(topestore360.)?tomtop.com$"|| req.http.host ~ "(?i)^(usbcity888.)?tomtop.com$"|| req.http.host ~ "(?i)^(dadidashop.)?tomtop.com$"|| req.http.host ~ "(?i)^(duoduobox.)?tomtop.com$"|| req.http.host ~ "(?i)^(anderlink.)?tomtop.com$") {# set req.http.host = "127.0.0.1";set req.backend = default;#如果为images.example.com,设置后端服务器为images} elsif (req.http.host ~ "(?i)^www.tomorrowtop.net$") {set req.backend = weike;return (pass);} elsif (req.http.host ~ "(?i)^blog.tomtop.com$") {set req.backend = tomtopblog;return (pass);} elsif (req.http.host ~ "(?i)^cnblog.tomtop.com$") {set req.backend = tomtopcnblog;return (pass);} elsif ((req.http.host ~ "(?i)^www.faspeed.com$")||(req.http.host ~ "(?i)^faspeed.com$")) {set req.backend = faspeed;return (pass);} elsif (req.http.host ~ "(?i)^173.192.59.7$") {set req.backend = phpmyadmin;# set req.http.host = "127.0.0.1";return (pass);} elsif (req.http.host ~ "(?i)^173.192.59.2$") {set req.backend = nagios;return (pass);} else {error 404 "Unknown virtual host";}remove req.http.X-real-ip;  set req.http.X-real-ip = client.ip;  set req.http.X-Forwarded-For = client.ip;  if (req.request == "GET" && (req.url ~ "\?imgurl.*\.(png|jpg|jpeg|gif|css)$")) {return (lookup);}if (req.request == "GET" && (req.url ~ "\.css$" || req.url ~ "print.css")) {return (lookup);}#purge allif (req.request == "BAN") {#if (!client.ip ~ purge) {#    error 405 "Not allowed.";#}ban("req.url ~ " + req.url );#error 200 "Purged.";return (lookup);}if (req.request == "POST") {return (pass);}if (req.http.Authorization) {/* Not cacheable by default */return (pass);}#if (req.url == "/") {#    return (pass);#}if (req.url ~ "^/tomtopadmin" || req.url ~ "^/index.php/tomtopadmin") {return (pass);}
#we should not cache any page for checkout and customer modulesif (req.request == "GET" && (req.url ~ "^/checkout" || req.url ~ "^/customer" || req.url ~ "^/varnish" || req.url ~ "^/vynamic")) {return (pass);}# normalize Accept-Encoding to reduce varyif (req.http.Accept-Encoding) {if (req.http.User-Agent ~ "MSIE 6") {unset req.http.Accept-Encoding;} elsif (req.http.Accept-Encoding ~ "gzip") {set req.http.Accept-Encoding = "gzip";} elsif (req.http.Accept-Encoding ~ "deflate") {set req.http.Accept-Encoding = "deflate";} else {unset req.http.Accept-Encoding;}}return (pass);
}

/usr/local/varnish/etc/varnish/include/footer.vcl:

sub vcl_hash {if (req.http.host) {hash_data(req.http.host);} else {hash_data(server.ip);}if (req.url ~ "\?acc=.*" && (req.url !~ "\?acc=.*&.*" && req.url !~ "\?.*&acc=.*" ) ) {hash_data(regsub(req.url, "\?.*", ""));}elseif (req.url ~ "\?aid=.*" && (req.url !~ "\?aid=.*&.*" && req.url !~ "\?.*&aid=.*" ) ) {hash_data(regsub(req.url, "\?.*", ""));}elseif(req.url ~ "\?aid=.*&bannerid=.*"){hash_data(regsub(req.url, "\?.*", ""));}else {hash_data(req.url);}#hash_data(req.url);if (regsub(req.http.Cookie, ".*currency=([A-Z]*).*", "\1") ~ "=") {hash_data("USD");} else {hash_data(regsub(req.http.Cookie, ".*currency=([A-Z]*).*", "\1"));}if (regsub(req.http.Cookie, ".*country=([A-Z]*).*", "\1") ~ "=") {hash_data("US");} else {hash_data(regsub(req.http.Cookie, ".*country=([A-Z]*).*", "\1"));}return (hash);
}sub vcl_hit {if (req.request == "BAN") {purge;error 200 "Hit Purged.";}return (deliver);
}sub vcl_miss {if (req.request == "BAN") {#purge;#error 200 "Miss Purged.";}return (fetch);
}sub vcl_fetch {set beresp.ttl = 86400 s;  // default cache 12 hoursif (req.url ~ "^/(\?|$)") {return (deliver);}if (beresp.status == 302) {return (hit_for_pass);}#Saint modeif (beresp.status == 500 || beresp.status == 502 || beresp.status == 503 || beresp.status == 504) { set beresp.saintmode = 5m;return (restart); }#Fix a strange problem: HTTP 301 redirects to the same page sometimes go in$if (beresp.http.Location == "http://" + req.http.host + req.url) {if (req.restarts > 2) {unset beresp.http.Location;#set beresp.http.X-Restarts = req.restarts;} else {return (restart);}}return (hit_for_pass);
}sub vcl_deliver {if (obj.hits > 0) {set resp.http.X-Cache = "HIT";} else {set resp.http.X-Cache = "MISS";}   return (deliver);
}sub vcl_error {set obj.http.Content-Type = "text/html; charset=utf-8";set obj.http.Retry-After = "5";synthetic {"
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html><head><title></title><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"></head><script>function to_home() {window.location.href = "http://www.tomtop.com";}</script><body><center>Oops! Something unexpected happens. Our support team has been notified. <br/>Please try again(by refleshing the page) shortly or call our customer service or <a href="http://www.tomtop.com/webmaster">report a site bug for us</a>.<br/>Will redirect to <a href="http://www.tomtop.com">home</a> page in 10 seconds.</center><script>window.setTimeout('to_home()', 5000);</script></body>
</html>
"};return (deliver);
}




#新建文件,用来做缓存输出。
mkdir /data/varnish/cachetouch /data/varnish/cache/varnish_cache.datagroupadd varnish
useradd -g varnish varnish  
uuidgen >/usr/local/varnish/etc/varnish/secret
chmod 644 /usr/local/varnish/etc/varnish/secret
ln  /usr/local/varnish/sbin/varnishd   /usr/sbin/varnishd 
/etc/init.d/varnish restart





4

下载magento插件varnish,

由于magento的varnish在1.8是不好用的,因为1.8中的加入购物链接存在form_key,所以会不好用,下面这个链接修复了这个功能:

http://download.csdn.net/detail/terry_water/6974513

安装

完成后,在后台打开varnish即可,

参考图片:




5
覆盖varnish.vcf到(需要编辑ip)
/usr/local/varnish/etc/varnish/default.vcl
下载地址:http://download.csdn.net/detail/terry_water/6970943

设置nginx的端口改为90
重启nginx


6
启动varnish
/usr/local/varnish/sbin/varnishd -f /usr/local/varnish/etc/varnish/default.vcl -s file, </data/varnish/cache/varnish_cache.data> ,1G -T 121.199.39.117:2000 -a :80


注意,网站配置一定是域名根目录,不要加子域名。


7注意:

在配置的时候,因为varnish指向的是12.0.0.1,所以,在配置nginx的时候,需要把127.0..0.1配置进去。

server_name 127.0.0.1,121.199.39.177;

如果出现加入购物车失败,则:

system-->configuration

web-->session cookie manager

cookie lifetime:36000000


8

如果想开启调试功能:

那么:

在magento后台开启:







如果多次出现miss的情况,请清空浏览器cookie,重新试


9

备注:

magento1.8安装后,会出现无法加入购物车的现象,这是因为1.8加入了form_key,需要是为了防止 XSS attacks

可以通过ajax异步获取form_key,加入,也可以通过下面的方法:

https://bitbucket.org/supportdesk_nl/turpertine-formkey-workaround/downloads

插件下载地址为:

http://download.csdn.net/detail/terry_water/6973299


其他:

https://github.com/nexcess/magento-turpentine/issues/345




10

Varnish-3.0.4 error.: 

Leaving directory `/root/lnmp/src/varnish-3.0.4/bin/varnishadm'
 报错后,安装3.0.3的步骤

varnishadm.c:48:33: error: editline/readline.h:No such file or directory
varnishadm.c:Infunction'cli_write':
varnishadm.c:76: warning: implicit declaration of function'rl_callback_handler_remove'
varnishadm.c:76: warning: nested extern declaration of 'rl_callback_handler_remove'
varnishadm.c:Infunction'send_line':
varnishadm.c:179: warning: implicit declaration of function'add_history'
varnishadm.c:179: warning: nested extern declaration of 'add_history'
varnishadm.c:Infunction'varnishadm_completion':
varnishadm.c:216: warning: implicit declaration of function'rl_completion_matches'
varnishadm.c:216: warning: nested extern declaration of 'rl_completion_matches'
varnishadm.c:216: warning: assignment makes pointer from integer without a cast
varnishadm.c:Infunction'pass':
varnishadm.c:233: error:'rl_already_prompted' undeclared (first use in this function)
varnishadm.c:233: error:(Each undeclared identifier is reported only once
varnishadm.c:233: error:for each function it appears in.)
varnishadm.c:235: warning: implicit declaration of function'rl_callback_handler_install'
varnishadm.c:235: warning: nested extern declaration of 'rl_callback_handler_install'
varnishadm.c:239: error:'rl_attempted_completion_function' undeclared (first use in this function)
varnishadm.c:300: warning: implicit declaration of function'rl_forced_update_display'
varnishadm.c:300: warning: nested extern declaration of 'rl_forced_update_display'
varnishadm.c:303: warning: implicit declaration of function'rl_callback_read_char'
varnishadm.c:303: warning: nested extern declaration of 'rl_callback_read_char'
make[3]:***[varnishadm-varnishadm.o]Error1
make[3]:Leaving directory `/root/lnmp/src/varnish-3.0.4/bin/varnishadm'
make[2]: *** [all-recursive] Error 1
make[2]: Leaving directory `/root/lnmp/src/varnish-3.0.4/bin'
make[1]: *** [all-recursive] Error 1
make[1]: Leaving directory `/root/lnmp/src/varnish-3.0.4'
make:***[all]Error2

Error not find a solution, varnish-3.0.3

wget http://repo.varnish-cache.org/source/varnish-3.0.3.tar.gz
tar xzf varnish-3.0.3.tar.gz
cd varnish-3.0.3
export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig
./configure --prefix=/usr/local/varnish --enable-debugging-symbols --enable-developer-warnings --enable-dependency-tracking --with-jemalloc
make && make install
/usr/bin/install -m 755./redhat/varnish.initrc /etc/init.d/varnish
/usr/bin/install -m 644./redhat/varnish.sysconfig /etc/sysconfig/varnish
/usr/bin/install -m 755./redhat/varnish_reload_vcl /usr/local/varnish/bin
useradd -M -s /sbin/nologin varnishln -s /usr/local/varnish/sbin/varnishd /usr/sbin/
ln -s /usr/local/varnish/bin/varnish_reload_vcl /usr/bin/
ln -s /usr/local/varnish/bin/varnishadm /usr/bin/chkconfig --add varnish
chkconfig varnish on

Generate varnish management key:

uuidgen >/usr/local/varnish/etc/varnish/secret
chmod 644/usr/local/varnish/etc/varnish/secret

Modify the varnish boot configuration:

sed -i "s@^VARNISH_VCL_CONF=/etc/varnish/default.vcl@#VARNISH_VCL_CONF=/etc/varnish/default.vcl\nVARNISH_VCL_CONF=/usr/local/varnish/etc/varnish/linuxeye.vcl@"/etc/sysconfig/varnish
sed -i "s@^VARNISH_LISTEN_PORT=6081@#VARNISH_LISTEN_PORT=6081\nVARNISH_LISTEN_PORT=80@"/etc/sysconfig/varnish
sed -i "s@^VARNISH_SECRET_FILE=/etc/varnish/secret@#VARNISH_SECRET_FILE=/etc/varnish/secret\nVARNISH_SECRET_FILE=/usr/local/varnish/etc/varnish/secret@"/etc/sysconfig/varnish
sed -i "s@^VARNISH_STORAGE_FILE=/var/lib/varnish/varnish_storage.bin@#VARNISH_STORAGE_FILE=/var/lib/varnish/varnish_storage.bin\nVARNISH_STORAGE_FILE=/usr/local/varnish/var/varnish_storage.bin@"/etc/sysconfig/varnish
sed -i "s@^VARNISH_STORAGE_SIZE.*@VARNISH_STORAGE_SIZE=150M@"/etc/sysconfig/varnish
sed -i "s@^VARNISH_STORAGE=.*@VARNISH_STORAGE=\"malloc,\${VARNISH_STORAGE_SIZE}\"@"/etc/sysconfig/varnish

If your server has multiple logic processor, also can do the following settings: &rdquo parameter, 
/etc/sysconfig/varnish can also add custom; -p parameter “ way to add, such as:

DAEMON_OPTS="-a ${VARNISH_LISTEN_ADDRESS}:${VARNISH_LISTEN_PORT} \-f ${VARNISH_VCL_CONF} \-T ${VARNISH_ADMIN_LISTEN_ADDRESS}:${VARNISH_ADMIN_LISTEN_PORT} \-t ${VARNISH_TTL} \-w ${VARNISH_MIN_THREADS},${VARNISH_MAX_THREADS},${VARNISH_THREAD_TIMEOUT} \-u varnish -g varnish \-S ${VARNISH_SECRET_FILE} \-s ${VARNISH_STORAGE} \-p thread_pools=2"#Here to add items

Varnish started to run in the background, and return to command state. Of note, the Varnish runtime will also start the two process, a main course, a child process, if the child process problems, the main process will produce a sub process.

The VCL configuration
/usr/local/varnish/etc/varnish/linuxeye.vcl.sh

#The backend defines a name for the webserver backend host, “.Host” specify the backend host IP address or domain name, “.Port” specify the backend host service port. 
backend webserver {.host ="127.0.0.1";.port ="8080";}#Call vcl_recv
sub vcl_recv {if(req.restarts ==0){if(req.http.x-forwarded-for){set req.http.X-Forwarded-For=req.http.X-Forwarded-For+", "+ client.ip;}else{set req.http.X-Forwarded-For= client.ip;}}#If the request is not of type GET, HEAD, PUT, POST, TRACE, OPTIONS, DELETE, enter pipe mode. Note that there is “ & & ” relationshipif(req.request !="GET"&&req.request !="HEAD"&&req.request !="PUT"&&req.request !="POST"&&req.request !="TRACE"&&req.request !="OPTIONS"&&req.request !="DELETE"){return(pipe);}#If the request is not of type GET and HEAD, then enter pass modeif(req.request !="GET"&& req.request !="HEAD"){return(pass);}if(req.http.Authorization|| req.http.Cookie){return(pass);}#The linuxeye.com domain name caching acceleration, this is the concept of a universal domain, all at the end of the linuxeye.com domain name cacheif(req.http.host ~"^(.*).linuxeye.com"){set req.backend = webserver;}#On.Jsp,.Do, and PHP end with? URL, direct read content from the backend serverif(req.url ~"\.(jsp|do|php)($|\?)"){return(pass);}else{return(lookup);}}sub vcl_pipe {return(pipe);}sub vcl_pass {return(pass);}sub vcl_hash {hash_data(req.url);if(req.http.host){hash_data(req.http.host);}else{hash_data(server.ip);}return(hash);}sub vcl_hit {return(deliver);}sub vcl_miss {return(fetch);}#For the request type is GET, and the requested URL contains upload, then caching, cache time is 300 seconds, 5 minutes
sub vcl_fetch {if(req.request =="GET"&& req.url ~"^/upload(.*)$"){set beresp.ttl =300s;}if(req.request =="GET"&& req.url ~"\.(png|gif|jpg|jpeg|bmp|swf|css|js|html|htm|xsl|xml|pdf|ppt|doc|docx|chm|rar|zip|ico|mp3|mp4|rmvb|ogg|mov|avi|wmv|txt)$"){unset beresp.http.set-cookie;set beresp.ttl =30d;}return(deliver);}#The following is to add a Header mark, to determine whether the cache hit
sub vcl_deliver {if(obj.hits >0){set resp.http.X-Cache="HIT from demo.linuxeye.com";}else{set resp.http.X-Cache="MISS from demo.linuxeye.com";}return(deliver);}#Use vcl_error to a custom error page
sub vcl_error {set obj.http.Content-Type="text/html; charset=utf-8";set obj.http.Retry-After="5";synthetic {"
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0Strict//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html><head><title>"}+ obj.status +" "+ obj.response +{"</title></head><body><h1>Error "}+ obj.status +" "+ obj.response +{"</h1><p>"}+ obj.response +{"</p><h3>Guru Meditation:</h3><p>XID: "}+ req.xid +{"</p><hr><p>Varnish cache server</p></body>
</html>
"};return(deliver);}sub vcl_init {return(ok);}sub vcl_fini {return(ok);}

Check the VCL configuration is correct:

service varnish configtest

Or

varnishd -C -f /usr/local/varnish/etc/varnish/linuxeye.vcl

Start varnish:

service varnish start

Check the varnish status:

service varnish status

The dynamic loading VCL configuration:

service varnish reload

Stop varnish:

service varnish stop

80 port to view the current varnish monitoring:

# netstat -tpln | grep :80
tcp        000.0.0.0:800.0.0.0:*                   LISTEN      15249/varnishd
tcp        000.0.0.0:80800.0.0.0:*                   LISTEN      19468/nginx
tcp        00:::80:::*                        LISTEN      15249/varnishd

To view the varnish process:

# ps -ef | grep varnishd | grep -v grep
root     152481011:47?00:00:00/usr/sbin/varnishd -P /var/run/varnish.pid -a :80-f /usr/local/varnish/etc/varnish/linuxeye.vcl -T 127.0.0.1:6082-t 120-w 50,1000,120-u varnish -g varnish -S /usr/local/varnish/etc/varnish/secret -s malloc,150M
varnish  1524915248011:47?00:00:00/usr/sbin/varnishd -P /var/run/varnish.pid -a :80-f /usr/local/varnish/etc/varnish/linuxeye.vcl -T 127.0.0.1:6082-t 120-w 50,1000,120-u varnish -g varnish -S /usr/local/varnish/etc/varnish/secret -s malloc,150M

Varnish access log 
varnishncsa can use NCSA common log format (NCSA Common Log Format) HTTP request record to the log file.

/usr/bin/install -m 755./redhat/varnishncsa.initrc /etc/init.d/varnishncsa
chmod +x /etc/init.d/varnishncsa
chkconfig varnishncsa on
mkdir -p /usr/local/varnish/logs

Edit the varnishncsa boot configuration

ln -s /usr/local/varnish/bin/varnishncsa /usr/bin
sed -i 's@^logfile.*@logfile="/usr/local/varnish/logs/varnishncsa.log"@'/etc/init.d/varnishncsa

Start varnishncsa:

service varnishncsa start

The use of logrotate log file (polling day polling):

cat >/etc/logrotate.d/varnish << EOF
/usr/local/varnish/logs/varnishncsa.log {
daily
rotate 5
missingok
dateext
compress
notifempty
sharedscripts
postrotate[-e /var/run/varnishncsa.pid ]&& kill -USR1 \`cat /var/run/varnishncsa.pid\`
endscript
}
EOF

Log polling debug test:

logrotate -df /etc/logrotate.d/varnish


这篇关于手动 4- linux配置varnish的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/845171

相关文章

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

关于Maven中pom.xml文件配置详解

《关于Maven中pom.xml文件配置详解》pom.xml是Maven项目的核心配置文件,它描述了项目的结构、依赖关系、构建配置等信息,通过合理配置pom.xml,可以提高项目的可维护性和构建效率... 目录1. POM文件的基本结构1.1 项目基本信息2. 项目属性2.1 引用属性3. 项目依赖4. 构

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

Linux Mint Xia 22.1重磅发布: 重要更新一览

《LinuxMintXia22.1重磅发布:重要更新一览》Beta版LinuxMint“Xia”22.1发布,新版本基于Ubuntu24.04,内核版本为Linux6.8,这... linux Mint 22.1「Xia」正式发布啦!这次更新带来了诸多优化和改进,进一步巩固了 Mint 在 Linux 桌面

LinuxMint怎么安装? Linux Mint22下载安装图文教程

《LinuxMint怎么安装?LinuxMint22下载安装图文教程》LinuxMint22发布以后,有很多新功能,很多朋友想要下载并安装,该怎么操作呢?下面我们就来看看详细安装指南... linux Mint 是一款基于 Ubuntu 的流行发行版,凭借其现代、精致、易于使用的特性,深受小伙伴们所喜爱。对