
私は Scientific Linux 6.4 (64 ビット) で Varnish-3.0.5 を使用しています。
$ rpm -q varnish
varnish-3.0.5-1.el5.centos.x86_64
$ cat /etc/redhat-release
Scientific Linux release 6.4 (Carbon)
$ uname -a
Linux XXX.XXX.XXX 2.6.32-358.23.2.el6.x86_64 #1 SMP Wed Oct 16 11:13:47 CDT 2013 x86_64 x86_64 x86_64 GNU/Linux
$ curl XXX.XX.XX.XXX
<html>
<head>
<title>Page Unavailable</title>
<style>
body { background: #303030; text-align: center; color: white; }
#page { border: 1px solid #CCC; width: 500px; margin: 100px auto 0; padding: 30px; background: #323232; }
a, a:link, a:visited { color: #CCC; }
.error { color: #222; }
</style>
</head>
<body onload="setTimeout(function() { window.location = '/' }, 5000)">
<div id="page">
<h1 class="title">Page Unavailable</h1>
<p>The page you requested is temporarily unavailable.</p>
<p>We're redirecting you to the <a href="/">homepage</a> in 5 seconds.</p>
<div class="error">(Error 503 Service Unavailable)</div>
</div>
</body>
</html>
$
IP アドレスに対してError 503 Service Unavailable
実行するたびにバックエンドの少なくとも 1 つがダウンしている場合に、デフォルトの仮想ホストを構成する方法を見つけようとしています。503 を受け取らないようにするには、 内でもIP アドレスを指定する必要がありますか? または、どの仮想ホストをデフォルトにするかを指定する他の方法はありますか?curl
req.http.host
vcl_recv()
答え1
まず最初に、実際の VCL 構成を見ずにアドバイスするのは非常に難しいと言わせてください。
実際の質問に回答するには
の始めにデフォルトのホストを設定できますvcl_recv
。バックエンドは、そのホストに応答するように設定する必要があります。
sub vcl_recv {
/* set a default host if no host is provided on the request or if it is empty */
if ( ! req.http.host
|| req.http.host == "") {
set req.http.host = "your.default.host.tld";
}
# ...
}
IP や をいじる必要はないと思いますがreq.http.host
、 curl を使用してホスト ヘッダーを varnish に渡す方がよいでしょう ( のようなものcurl -H "Host: your.default.host.tld" http://XX.XX.XX.XXX/
)
このトピックに関する一般的な提案:
VCLに不正な制御ロジックを追加する [1]
バックエンドを正しく設定していますか?
VCLロジックで他のものを使用するように指示されない限り、varnishは「デフォルト」のバックエンド(またはディレクター)を使用することに注意してください。
ヘルスプローブを追加して、どのバックエンドが失敗しているかを確認します
一貫性のあるヘルスプローブ[2]を使用し、コマンドラインコマンドを使用する。varnishadm debug.health
より理解を深めるにはドキュメントを参照のこと[3]
VLCエラーに再起動ロジックを追加する
このようなもの
sub vcl_error {
# ...
/* Try to restart request in case of failure */
if (obj.status == 503 && req.restarts < 5) {
set obj.http.X-Restarts = req.restarts;
return(restart);
}
# Before any deliver
return (deliver);
}
VLCエラー合成応答にデバッグロジックを追加する
vcl_fetch
バックエンド エラー コードを Varnish エラー応答に渡すときにデバッグ ヘッダーを追加できることを覚えておいてください。
sub vcl_fetch {
# ...
set beresp.http.X-Debug-Backend-Code = beresp.status;
# ...
}
sub vcl_error {
# ...
synthetic {""
# Insert the following at the end of your current response
<p>Backend Status code was "} + obj.http.X-Debug-Backend-Code + {"</p>
</body>
</html>
"};
# ...
return (deliver);
}
[1]https://www.varnish-cache.org/docs/3.0/tutorial/handling_misbehaving_servers.html
[2]https://www.varnish-cache.org/docs/3.0/reference/vcl.html#backend-probes
[3]https://www.varnish-cache.org/trac/wiki/BackendPolling#CLIcommands